- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在编写一个开源库。我正在使用两个 Remote :一个用于个人测试平台和备份的私有(private)存储库,另一个在 github 上托管的公共(public)存储库。
在私有(private)仓库中,我在这里保存并进行了大量提交和推送,并进行了所有小的更改,例如“修复拼写”或“仍在处理错误 #123!”。这很好,我想保持这种状态。私有(private)仓库永远不会与任何人共享。
在 github 上的公共(public)仓库中,我希望我的 git 提交历史是干净的。将多个提交 merge 为一个提交,例如“修复错误 #123”。
问题是,如何在两个不同的远程仓库上维护两个独立的 git 历史记录?
我一直在阅读有关 git rebase
的文章。 rebase
会改变那个分支的整个历史吗?如果我为公共(public) repo 更改历史记录,私有(private) repo 是否也会更改?
如果我维护两个分支会更好吗?是否有可能公共(public)服务器只看到一个分支(作为 master),而另一个看到两个具有详细提交的分支?
我不确定针对这种情况的最佳做法是什么。感谢您的宝贵时间。
最佳答案
The question is, how do I maintain two separate git history on two different remote repos?
我想提防你,那个分支不应该长寿。长期存在的分支有一天会变得一团糟,因为它应该与开发分支(或分支开始的分支)同步,这就是为什么鼓励您这样做的原因 git rebase develop
等等。
实际上,很难理解在不同远程拥有一个分支的两个版本有什么好处。在你的公共(public)仓库中有这个分支有什么意义,它将包含单个提交并且总是被强制更新?对我来说,这听起来像是无用的废话。
现实生活中的事情是怎样发生的:
您发布包含您已完成的所有提交的分支;
当功能完成并且每个人都同意将此分支 merge 到 develop
中时(或创建它的地方)分支可以压缩成单个提交或可以按原样 merge 。
您之前工作的远程功能分支应该被删除,因为它已 merge 到另一个分支,并且不会补充任何提交。
所以,除了你的分支是从哪个分支开始的,根本没有什么需要维护的。
按文字回答问题:
如果你想要一个单次提交的分支,其中包含你在当前分支中所做的所有更改,你可以这样做:
git diff ${SHA}
, 其中${SHA}
是您的分支开始的分支的最后一次提交。> patch.diff
.${SHA}
与 git checkout ${SHA}
.patch -p1 < patch.diff
应用补丁.git commit -m '...'
.git branch -m
重命名分支.git push ${REMOTE_NAME} ${BRANCH_NAME}
将其推送到远程.git reset HEAD~1
推送到公共(public)远程之前重置此提交.但是所有这些看起来都是普通开发人员永远不会使用的一堆丑陋的东西:[
关于git squash 为公共(public)服务器提交,但为私有(private)服务器保留详细的提交,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14545527/
如果需要在类外访问静态(例如单例),可以选择公共(public)静态而不是私有(private)静态,而当不需要公开函数时首选私有(private)静态(否则未命名的命名空间就可以了)——在这种情况下
在互联网上进行了一些搜索,但找不到简单的答案。我的问题集是在 Android 框架中使用 Java,但我相信这也是标准的 Java 行为。我理解 final 和 private 的定义,它们都用于变量
我有这个代码: public final class Board { private final int[][] blocks; private final int N; pr
对我来说,过去作为 Objective-C 开发人员很简单。一个类需要公开的每个字段都是一个属性,每个私有(private)字段都是一个没有 getter 或 setter 的实例变量。但我经常看到人
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我有一个在 Docker 容器中运行的应用程序。它需要来自公司私有(private) NPM 注册表(Sinopia)的一些私有(private)模块,并且访问这些需要用户身份验证。 Dockerfi
我试图理解 C# 使用 getters 和 setters 自动声明变量与 java 声明之间的区别。 在java中我通常这样做: private int test; public int getTe
我在 Azure 中创建了 VNET。我放入了一个子集 Azure Private Link,它在 VNET 之外和另一台虚拟机中调用 Azure Function。 当我尝试通过专用 IP 调用专用
我在 Azure 中创建了 VNET。我放入了一个子集 Azure Private Link,它在 VNET 之外和另一台虚拟机中调用 Azure Function。 当我尝试通过专用 IP 调用专用
我目前正在使用 Objective-C(适用于 iPhone)构建游戏。 为此,出于性能/复杂性原因,我略微打破了 MVC,并为 View (渲染器)提供了对模型的直接引用。这是因为它应该以 60fp
我已经在 ubuntu 上成功配置了 2 个虚拟主机站点(基于名称的虚拟主机)。我的 apache 版本是 2.2.22。 这两个站点都在本地主机上工作。 /etc/hosts 条目 127.0.0.
考虑下面的类 public class A { private final Map cache; public HeavyObject getThing(); } 假设不能泄漏对缓存
我有一个类,它有一个方法,我希望它只能被它的子对象访问,而不能被这个包中的其他类访问。 Modifier | Class | Package | Subclass | World ———————
本文实例讲述了JavaScript中的公有、私有、特权和静态成员用法。分享给大家供大家参考。具体分析如下: 下面的内容是在《JavaScript.DOM高级程序设计》里面摘抄出来的,比较容易理解,
我有一个用例,我已将其简化为以下程序: public class A { private int x = 100; class B { private int y = ne
问题: 类声明如下: class Select { public: template static Iterator function(Iterator , Iterator , bo
我是一名初级 PHP 程序员。我还有很多东西要学。这就是我问这个问题的原因。在一个类中,您有一个公共(public)函数,您可以从该类外部调用它。有时你有一个私有(private)函数,你可以在私有(
问题是: 何时使用私有(private)函数,何时使用嵌套函数? (我在问 F# 但也许答案可能与其他功能语言相关) 一个小例子 namespace SomeName module BinaryRea
我发现工作表中仍然可以使用私有(private)函数。它们是隐藏的,但如果用户输入他们的名字,他们就会被调用。为什么?它应该以这种方式工作吗?有没有办法完全阻止用户定义的函数在 VBA 项目之外使用?
所以我最近开始尝试使用 Kotlin,我偶然发现了这个: If a top-level declaration is marked private, it is private to the pack
我是一名优秀的程序员,十分优秀!