我们经常发布文档更新,此页面的翻译可能仍在进行中。有关最新信息,请访问英文文档。如果此页面上的翻译有问题,请告诉我们
文章版本: GitHub.com

Requiring a linear commit history

You can require a linear commit history to block all merge commits from a protected branch.

受保护分支适用于具有 GitHub Free 的公共仓库,以及具有 GitHub Pro、GitHub Team、GitHub Enterprise Cloud 及 GitHub Enterprise Server 的公共和私有仓库。 更多信息请参阅“GitHub 的产品”。

本文内容

Anyone with admin permissions to a repository can require a linear commit history.

About enforcement of linear commit history

Enforcing a linear commit history prevents merge commits from being pushed to the protected branch. This means that any pull requests merged into the protected branch must use a squash merge or a rebase merge. A strictly linear commit history can help teams backtrack changes more efficiently. For more information about merge methods, see "About pull request merges."

您可以自动为仓库中的部分或所有分支设置实施受保护分支设置。 更多信息请参阅“配置受保护分支”。

Before you can require a linear commit history, your repository must allow squash merging or rebase merging. For more information, see "Configuring pull request merges."

Enforcing a linear commit history

  1. 在 GitHub 上,导航到仓库的主页面。
  2. 在仓库名称下,单击 Settings(设置)
    仓库设置按钮
  3. 在左侧菜单中,单击 Branches(分支)
    仓库选项子菜单
  4. 在“Branch protection rules(分支保护规则)”旁边,单击 Add rule(添加规则)
    添加分支保护规则按钮
  5. 在“Branch name pattern(分支名称模式)”下,输入您要保护的分支名称或模式。
    分支规则字段
  6. Under "Protect matching branches", select Require linear history.
    Required linear history option
  7. 视情况可选择 Include administrators(包括管理员)。 这将强制执行所有配置的仓库管理员限制。
    包括管理员复选框
  8. Click Create.

问问别人

找不到要找的内容?

联系我们