- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在GitHub上用html + css + javascript
搭建了半年的项目。一直在私有(private)仓库,只有一个分支。
现在我想让这个存储库部分公开,这样:
用户可以使用issues
功能提出问题或写需求,我可以回复他们,我们可以讨论。
实际上,用户不需要看到代码。但由于我们在 GitHub 上,我可能想公开一小部分文件。
我不想丢失提交历史。
谁能告诉我应该遵循哪些步骤(最好是命令)?
我是否必须重新组织我的文件夹,例如,制作一个公共(public)文件夹和一个私有(private)文件夹?
最佳答案
首先要了解的是GitHub权限模型。提交问题等需要对 repo 的某种级别的许可。阅读应该足够了。
但阅读确实也意味着“能够看到所有代码和历史”。能够看到甚至意味着能够复制和 fork ,即使您控制可以写回您的存储库的内容。并且没有低于“读取(所有代码)”的访问级别。
因此,如果您想将自己的代码保密,那么在 github 之外创建某种项目页面,并利用那里的专用问题跟踪系统,可能对您尝试做的事情更有意义。
如果您确实决定某些 代码应该公开,那么您必须有两个存储库。带有公共(public)代码的 repo 可以设为只读,或者如果能更好地满足您对该代码子集的需求,则可以设为读/写。无论哪种方式,它都可以主持问题讨论等。
将代码子集拆分到公共(public)存储库中并不太,但如果您希望公共(public)存储库也具有完整的历史记录,那就更难了。您将希望避免创建两个不同的公共(public)代码历史记录,因此您可能必须从私有(private)存储库中删除公共(public)代码。 (它可以作为一个子模块重新引入 - 一个指向公共(public)存储库的链接 - 但在最简单的情况下,这意味着您需要将公共(public)代码组织在一个目录下。)
如果只需要公开当前版本,那就很简单了。您初始化新的存储库,将文件从一个移到另一个,如果需要,创建子模块链接。
如果您想发布已发布文件的历史记录,那么您必须执行类似 git filter-branch
的操作,以从原始存储库(的克隆)创建公共(public)存储库。确切的过程取决于具体的要求,但通常您可以使用 (a) subdirectory-filter
来仅发布一个目录的内容(到新 repo 的根目录)——但听起来就像您的代码没有安排得那么容易;或 (b) index-filter
删除您想要保密的文件(同时为剩余文件保留现有目录结构);或 (c) tree-filter
和一个你喜欢移动、删除或添加文件的复杂脚本,将“原始 repo ”版本转换为相应的“公共(public) repo ”版本。
如果您确实拆分了历史记录,您可能仍希望将公共(public)文件的历史记录保留在原始存储库中,因为链接存储库的历史记录相当困难。在大多数情况下,这并不是一个很大的实际限制,除非历史的规模相当可观。
关于GitHub:将私有(private)存储库部分公开,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44261626/
如果需要在类外访问静态(例如单例),可以选择公共(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
我是一名优秀的程序员,十分优秀!