[Git] 关于refs/for/ 和refs/heads/
来源:互联网 发布:淘宝账号名怎么改 编辑:程序博客网 时间:2024/05/17 00:17
转自http://lishicongli.blog.163.com/blog/static/146825902013213439500/
1. 这个不是git的规则,而是gerrit的规则,
2. Branches, remote-tracking branches, and tags等等都是对commite的引用(reference),引用都以 “refs/……”表示. 比如remote branch: origin/git_int(=refs/remotes/origin/git_int), local tag: v2.0(=refs/tags/v2.0), local branch: git_int(=refs/heads/git_int)…
3. 简单点说,就是refs/for/mybranch需要经过code review之后才可以提交;refs/heads/mybranch不需要code review。
(since you want to directly push into the branch, rather than create code reviews. Pushing to refs/for/* creates code reviews which must be approved and then submitted. Pushing to refs/heads/* bypasses review entirely, and just enters the commits directly into the branch. The latter does not check committer identity, making it appropriate for importing past project history)
如果需要code review,直接push
$git push origin master
那么就会有“! [remote rejected] master -> master (prohibited by Gerrit)”的错误信息
而这样push就没有问题,
$git push origin HEAD:refs/for/mybranch
下面一段是对“refs/for”更详细的描述:
The documentation for Gerrit explains that you push to the "magical refs/for/'branch' ref using any Git client tool".
This image is taken from the Intro to Gerrit. When you push to Gerrit, you do git push gerrit HEAD:refs/for/<BRANCH>. This pushes your changes to the staging area (in the diagram, "Pending Changes"). Gerrit doesn't actually have a branch called <BRANCH>; it lies to the git client.
Internally, Gerrit has it's own implementation for the Git and SSH stacks. This allows it to provide the "magical" refs/for/<BRANCH> refs.
When a push request is received to create a ref in one of these namespaces Gerrit performs its own logic to update the database, and then lies to the client about the result of the operation. A successful result causes the client to believe that Gerrit has created the ref, but in reality Gerrit hasn’t created the ref at all.
After a successful patch (i.e, the patch has been pushed to Gerrit, [putting it into the "Pending Changes" staging area], reviewed, and the review has passed), Gerrit pushes the change from the "Pending Changes" into the "Authoritative Repository", calculating which branch to push it into based on the magic it did when you pushed to refs/for/<BRANCH>. This way, successfully reviewed patches can be pulled directly from the correct branches of the Authoritative Repository.
- [Git] 关于refs/for/ 和refs/heads/
- [Git] 关于refs/for/ 和refs/heads/
- [Git] 关于refs/for/ 和refs/heads/
- [Git] 关于refs/for/ 和refs/heads/
- git中refs/for 和refs/heads
- refs/for/ 与refs/heads/
- 关于refs/for/
- 关于refs/for/
- 关于refs/for/
- brew update 失败 Error: Failed while executing git pull origin refs/heads/master:refs/remotes/origin/
- 当使用EGit(Eclipse Git)进行pull时,提示Could not get advertised Ref for branch refs/heads/xxx错误
- git push . :refs/for/foo 意思
- Git远程分支和refs文件详解
- Git远程分支和refs文件详解
- git push错误 remote: error: refusing to update checked out branch: refs/heads/master 解决方式
- git push时出现错误refusing to update checked out branch: refs/heads/master
- error: revision refs/heads/master in manifests not found
- fatal: Couldn't find remote ref refs/heads/cm-13.0
- c++五种内存分配、堆与栈区别
- java 简易http服务器原理
- 工业相机参数之帧率相关知识详解:
- Git Flow
- iOS抽奖转盘动画之转场动画与动画组
- [Git] 关于refs/for/ 和refs/heads/
- UIView的最常用知识
- 四、从数字中发现规律?
- 高并发量网站解决方案
- 习题二
- 虚幻4引擎快速入门视频教程
- 12家人均创收最高的科技公司
- 华为机试:过滤重复单词
- JAVA中的四种引用:强引用,软引用,弱引用,虚引用