- 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/
据我所知,在 C# 中,所有字段默认都是私有(private)的,如果没有另外标记的话。 class Foo { private string bar; } class Foo { strin
这个问题在这里已经有了答案: Why is it allowed to access Java private fields via reflection? (7 个答案) 关闭 6 年前。 使用反
在 C#(和许多其他语言)中,访问相同类型的其他实例的私有(private)字段是完全合法的。例如: public class Foo { private bool aBool; pu
使用私有(private)方法通过将一些决策点重构为单独的方法来降低 CC 会降低实际方法的 CC 并易于阅读,但不会减少在测试中获得完整分支覆盖的工作量。 这合理吗?你有什么现场经验? 最佳答案 好
在下面的例子中,模块outer有一个私有(private)类型Private和一个私有(private)内部模块inner。 inner 能够访问Private(因为子模块可以访问其父级的私有(pri
class Person def one @var = 99 self.two end private def two p @var end end p=P
我在 Azure 中创建了 VNET。我放入了一个子集 Azure Private Link,它在 VNET 之外和另一台虚拟机中调用 Azure Function。 当我尝试通过专用 IP 调用专用
我在 Azure 中创建了 VNET。我放入了一个子集 Azure Private Link,它在 VNET 之外和另一台虚拟机中调用 Azure Function。 当我尝试通过专用 IP 调用专用
我正在尝试获得良好的 Ruby 编码风格。为防止意外调用具有相同名称的局部变量,我总是在适当的地方使用 self.。但是现在我偶然发现了这个: class MyClass "method" a
今天遇到一个案例类构造函数的奇怪问题。我想将构造函数设为私有(private),看来这不是问题。所以我已经在我的一个项目中尝试过它并且它有效。但在另一个项目中,我可以调用私有(private)构造函数
我想坚持使用记录,并且不想返回对象。所以我想知道是否可以将记录的字段设置为私有(private)?或者创建记录的私有(private)成员。其他具体类型(例如可区分联合)怎么样? 或者,这个要求是否违
我正在通过 Flickr API 进行经过身份验证的调用来访问照片。但我只得到我的公开照片,而没有任何私有(private)照片。 下面给出的是我正在使用的代码, Flickr f; Request
这两个类的行为不同;原因似乎与使用 private[this] 声明而不是 private 有关。有人可以解释一下为什么吗? 私有(private): class Person( private
在 private 中的 1000 秒 private 之后,我想到可能不需要它 public class Outer { private static class Inner { // yo
我有以下代码: class C { private enum E { // ... } } private extension C { func f(e: E)
OOP 语言中是否有object-private 的概念??我的意思是比经典的私有(private)访问限制更多? Private (or class-private) restricts the a
swift 3.0 我知道fileprivate访问级别修饰符将函数/属性的使用限制在声明它的源文件和 private - 仅限于声明的词法范围。但似乎这条规则不适用于扩展。例如。此代码有效: cla
即将推出的 Delphi 版本中启用该功能的功能怎么样? 也许它可能是一个编译器开关,促进所有 ** private **s to ** strict private **小号。 ... 或者它可能是
我可以通过将函数放入类的私有(private)扩展中来创建私有(private)函数,而不是通过不断调用 private func functionName(){} 来创建新的私有(private)函
部署专用端点并需要专用 IP 地址作为输出,但似乎无法正确获取值查询。下面的结果是“模板输出'主机名'无效:语言表达式属性|'privateIPAddress'具有无效的数组索引..(代码:Deplo
我是一名优秀的程序员,十分优秀!