7

在我的项目中,我通常有一个(开发)分支通向下一个发布版本,此时开发分支将合并到发布分支中,然后将创建一个新的开发分支。

这意味着,两个分支 HEAD 将指向同一个提交:

$> cd project.git  
$> rgrep release .  
    ./packed-refs:2808f1de3e05bf7fcc509c20f31a93e2ba645bd3 refs/heads/release  
$> rgrep 2808f1de3e05bf7fcc509c20f31a93e2ba645bd3 .  
    ./packed-refs:2808f1de3e05bf7fcc509c20f31a93e2ba645bd3 refs/heads/release  
    ./packed-refs:2808f1de3e05bf7fcc509c20f31a93e2ba645bd3 refs/heads/development_0103  

我希望从我的 repo 克隆的人自动检查发布分支。

$> cd project.git  
$> git symbolic-ref HEAD  
    refs/heads/release  

但是,当从那个 repo 克隆时,显然人们会签出按字母顺序排列的第一个匹配分支

$> git clone project.git/ project.clone  
$> cd project.clone  
$> git status  
    # On branch development_0103  
    nothing to commit (working directory clean)  

在我看来,git 正在通过查看 SHA1 来计算要检查的分支名称,但实际上并未使用遥控器的符号头 HEAD。

有什么办法可以解决这个问题并使克隆默认为“release”而不是“development_0103”?

4

1 回答 1

1

您可以使用单独的远程存储库来推送公共版本,而不是使用您的方式。您将在您的开发远程仓库中照常工作。将稳定提交合并到发布分支。之后git push release_origin release。因此,您只能与其他人共享此 release_origin 存储库。

或者还有另一个黑客攻击。:) 只需将您的发布分支重命名为 a_release,因此它将按字母顺序排列。:)

于 2011-03-03T09:59:37.563 回答