关于分支
分支是一个新的仓库,它与原始的“上游”仓库共享代码和可见性设置。分支通常用于在将想法或更改提议回上游仓库之前进行迭代,例如在开源项目中或当用户没有上游仓库的写入权限时。有关更多信息,请参阅 "使用分支."
向他人的项目提出更改
例如,您可以使用分支来提出与修复错误相关的更改。与其记录您发现的错误的 issue,您可以
- 派生仓库。
- 进行修复。
- 向项目所有者提交拉取请求。
将其他人的项目用作您自己想法的起点。
开源软件基于这样的理念:通过共享代码,我们可以制作出更好、更可靠的软件。有关更多信息,请参阅开源计划的“关于开源计划”。
有关在 GitHub.com 上将开源原则应用于组织开发工作的更多信息,请参阅 GitHub 的白皮书“内部开源简介”。
从他人项目的 fork 创建公共仓库时,请务必包含一个许可证文件,该文件确定您希望如何与他人共享您的项目。有关更多信息,请参阅 choosealicense.com 上的“选择开源许可证”。
有关开源的更多信息,特别是如何创建和发展开源项目,我们创建了 开源指南,这些指南将通过推荐创建和维护开源项目仓库的最佳实践来帮助您培养健康的开源社区。您还可以参加关于维护开源社区的免费 GitHub 技能 课程。
先决条件
如果您尚未设置,请先从 Git 设置 Git 和 GitHub.com 的身份验证。有关更多信息,请参阅“设置 Git”。
Fork 仓库
您可能会 fork 项目以向上游仓库提出更改。在这种情况下,定期将您的 fork 与上游仓库同步是一个好习惯。为此,您需要在命令行上使用 Git。您可以使用刚刚 fork 的相同 octocat/Spoon-Knife 仓库练习设置上游仓库。
-
在 GitHub.com 上,导航到 octocat/Spoon-Knife 仓库。
-
在页面右上角,单击 **Fork**。
-
在“所有者”下,选择下拉菜单并单击 fork 仓库的所有者。
-
默认情况下,fork 的名称与其上游仓库相同。可选地,为了进一步区分您的 fork,在“仓库名称”字段中键入一个名称。
-
可选地,在“描述”字段中键入 fork 的描述。
-
可选地,选择 **仅复制 DEFAULT 分支**。
对于许多 fork 场景,例如为开源项目做出贡献,您只需要复制默认分支。如果您不选择此选项,所有分支都将复制到新的 fork 中。
-
单击 **创建 fork**。
**注意:**如果您想从上游仓库复制其他分支,您可以从 **分支** 页面进行操作。有关更多信息,请参阅“在仓库中创建和删除分支”。
要了解有关 GitHub CLI 的更多信息,请参阅“关于 GitHub CLI”。
要创建仓库的分支,请使用gh repo fork
子命令。
gh repo fork REPOSITORY
要在组织中创建分支,请使用--org
标志。
gh repo fork REPOSITORY --org "octo-org"
您可以在GitHub.com或GitHub Desktop上创建仓库的分支。有关在GitHub.com上创建分支的信息,请参阅本文的网页浏览器版本。
在GitHub Desktop中,如果您尝试克隆一个您没有写入权限的仓库,系统会自动为您创建一个分支。
-
在**文件**菜单中,单击**克隆仓库**。
-
单击与您要克隆的仓库位置相对应的选项卡。您也可以单击**URL**手动输入仓库位置。
-
从仓库列表中,单击您要克隆的仓库。
-
要选择要克隆仓库的本地目录,请在“本地路径”字段旁边,单击**选择...**并导航到该目录。
-
在“克隆仓库”窗口的底部,单击**克隆**。
-
阅读“您打算如何使用此分支?”窗口中的信息。
- 如果您打算使用此分支来贡献到原始上游仓库,请单击**贡献到父项目**。
- 如果您打算将此分支用于与上游无关的项目,请单击**用于我自己的目的**。
-
单击**继续**。
克隆您的分支仓库
现在,您已经有了Spoon-Knife仓库的分支,但您还没有将该仓库中的文件本地存储在您的计算机上。
-
在GitHub.com上,导航到**您分支的**Spoon-Knife仓库。
-
在文件列表上方,单击 代码.
-
复制仓库的URL。
-
要使用HTTPS克隆仓库,请在“HTTPS”下,单击 .
-
要使用SSH密钥克隆仓库,包括由您的组织的SSH证书颁发机构颁发的证书,请单击**SSH**,然后单击 .
-
要使用GitHub CLI克隆仓库,请单击**GitHub CLI**,然后单击 .
-
-
打开终端终端Git Bash。
-
将当前工作目录更改为要放置克隆目录的位置。
-
输入
git clone
,然后粘贴您之前复制的 URL。它将如下所示,使用您的 GitHub 用户名代替YOUR-USERNAME
git clone https://github.com/YOUR-USERNAME/Spoon-Knife
-
按 Enter 键。您的本地克隆将被创建。
$ git clone https://github.com/YOUR-USERNAME/Spoon-Knife > Cloning into `Spoon-Knife`... > remote: Counting objects: 10, done. > remote: Compressing objects: 100% (8/8), done. > remote: Total 10 (delta 1), reused 10 (delta 1) > Unpacking objects: 100% (10/10), done.
要了解有关 GitHub CLI 的更多信息,请参阅“关于 GitHub CLI”。
要创建您的 fork 的克隆,请使用 --clone
标志。
gh repo fork REPOSITORY --clone=true
-
在**文件**菜单中,单击**克隆仓库**。
-
单击与您要克隆的仓库位置相对应的选项卡。您也可以单击**URL**手动输入仓库位置。
-
从仓库列表中,单击您要克隆的仓库。
-
要选择要克隆仓库的本地目录,请在“本地路径”字段旁边,单击**选择...**并导航到该目录。
-
在“克隆仓库”窗口的底部,单击**克隆**。
配置 Git 以将您的 fork 与上游存储库同步
当您 fork 一个项目以向上游存储库提出更改时,您可以配置 Git 将更改从上游存储库拉取到您的 fork 的本地克隆中。
-
在 GitHub.com 上,导航到 octocat/Spoon-Knife 仓库。
-
在文件列表上方,单击 代码.
-
复制仓库的URL。
-
要使用HTTPS克隆仓库,请在“HTTPS”下,单击 .
-
要使用SSH密钥克隆仓库,包括由您的组织的SSH证书颁发机构颁发的证书,请单击**SSH**,然后单击 .
-
要使用GitHub CLI克隆仓库,请单击**GitHub CLI**,然后单击 .
-
-
打开终端终端Git Bash。
-
将目录更改为克隆的 fork 的位置。
- 要转到您的主目录,只需输入
cd
,不输入其他文本。 - 要列出当前目录中的文件和文件夹,请输入
ls
。 - 要进入列出的目录之一,请输入
cd YOUR-LISTED-DIRECTORY
。 - 要向上移动一个目录,请输入
cd ..
。
- 要转到您的主目录,只需输入
-
输入
git remote -v
并按 Enter 键。您将看到为您的 fork 配置的当前远程存储库。$ git remote -v > origin https://github.com/YOUR-USERNAME/YOUR-FORK.git (fetch) > origin https://github.com/YOUR-USERNAME/YOUR-FORK.git (push)
-
输入
git remote add upstream
,然后粘贴您在步骤 3 中复制的 URL 并按 Enter 键。它将如下所示git remote add upstream https://github.com/ORIGINAL-OWNER/Spoon-Knife.git
-
要验证为您的 fork 指定的新上游存储库,请再次输入
git remote -v
。您应该看到您的 fork 的 URL 作为origin
,以及上游存储库的 URL 作为upstream
。$ git remote -v > origin https://github.com/YOUR-USERNAME/YOUR-FORK.git (fetch) > origin https://github.com/YOUR-USERNAME/YOUR-FORK.git (push) > upstream https://github.com/ORIGINAL-OWNER/ORIGINAL-REPOSITORY.git (fetch) > upstream https://github.com/ORIGINAL-OWNER/ORIGINAL-REPOSITORY.git (push)
现在,您可以使用一些 Git 命令将您的 fork 与上游存储库保持同步。有关更多信息,请参阅“同步 fork”。
要了解有关 GitHub CLI 的更多信息,请参阅“关于 GitHub CLI”。
要为 fork 的存储库配置远程存储库,请使用 --remote
标志。
gh repo fork REPOSITORY --remote=true
要指定远程存储库的名称,请使用 --remote-name
标志。
gh repo fork REPOSITORY --remote-name "main-remote-repo"
编辑 fork
您可以对 fork 进行任何更改,包括
- 创建分支: 分支 允许您构建新功能或测试想法,而不会危及您的主要项目。
- 打开拉取请求:如果您想为上游存储库做出贡献,您可以通过提交 拉取请求 向原始作者发送请求,要求他们将您的 fork 拉取到他们的存储库中。
查找另一个要 fork 的存储库
fork 一个存储库以开始为项目做出贡献。您可以将任何公共存储库 fork 到您的个人帐户,或 fork 到您有权创建存储库的组织。如果您有权访问私有存储库,并且所有者允许 fork,您可以将存储库 fork 到您的个人帐户,或 fork 到您有权创建存储库的 GitHub 团队。您无法使用 GitHub Free 将私有存储库 fork 到组织。有关 GitHub 团队和 GitHub Free 的更多信息,请参阅“GitHub 的计划”。有关何时可以 fork 存储库的更多信息,请参阅“关于 fork 的权限和可见性”。
您可以浏览 GitHub 探索 查找项目并开始为开源存储库贡献。有关更多信息,请参阅“在 GitHub 上寻找为开源贡献的方法”。
下一步
您现在已经 fork 了一个存储库,练习了克隆您的 fork,并配置了上游存储库。
-
有关从计算机克隆 fork 和同步 fork 存储库中更改的更多信息,请参阅“设置 Git”。
-
您还可以创建一个新的存储库,您可以在其中放置所有项目并在 GitHub 上共享代码。为您的项目创建存储库可以让您将代码存储在 GitHub 上。这将为您提供一个工作备份,您可以选择与其他开发人员共享。有关更多信息,请参阅“存储库快速入门”。
-
GitHub 上的每个存储库都归个人或组织所有。您可以通过在 GitHub 上连接和关注他们来与人员、存储库和组织进行互动。有关更多信息,请参阅“在 GitHub 上寻找灵感”。
-
GitHub 拥有一个很棒的支持社区,您可以在其中寻求帮助并与来自世界各地的人们交流。加入 GitHub 社区 的对话。