- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在将 git 用作机器几周后,现在我正在弄清楚 GIT 的真正工作原理。比起我从一件简单的事情开始:
git checkout -b test origin/development` //Creating new local branch from development
Create new text file called test.txt
git add . //Set files that will be committed
git commit -m "this is a test" // Committing
然后是我的疑问:
当我尝试 push 做的时候:
git push origin development
日志说:一切都是最新的
如果我尝试 push 做:
git push origin HEAD:development
它正常工作。
通过研究,我发现 HEAD 表示当前分支的名称。所以,如果它是对的,那对我来说没有任何意义。
有什么区别
git push origin development
和
git push origin HEAD:development
最佳答案
git push remote-name some-name
尝试将任何名为some-name
的本地 分支推送到也名为some-name
的远程分支在 remote-name/some-name
解析。在引擎盖下,它在匹配的每个位置(本地、远程)的 refs
下寻找分支名称。
由于您的 development
的本地副本尚未修改,您会收到一条消息,表明它是最新的,无需推送。
替代版本
git push remote-name HEAD:development
跳过有关在本地和远程 refs
中查找匹配分支名称的部分,因为您已通过 HEAD
为其指定了一个显式分支。
它仍然使用远程 refs
来确定远程分支 development
。但随后它使用当前分支(您的新 test
分支)的 HEAD
来推送提交。
如果你想简单地从 test
分支执行 git push
并正确地从 test
推送到 remote/development
,您可以将 push
的默认行为配置为“上游”设置(请注意,术语“跟踪”是“上游”的旧术语,首选)。
做
git config --global push.default upstream
确保普通 git push
只会尝试从当前分支推送到其注册的上游分支。
如果没有设置,在 git 版本 2.0 之前,普通 git push
的默认模式会导致尝试将 所有 本地分支推送到具有匹配名称的上游分支他们配置的 Remote 。对于 git 2.0 和更新版本,默认设置是 simple
,它的作用类似于 upstream
,除了如果当前分支与其配置的名称不同,它也无法推送远程。
“上游”设置是一个很好的设置,因为 (a) 它允许轻松推送分支,无论它们的名称是否与上游名称匹配; (b) 对于 2.0 之前的版本,它将 git push
的简单调用限制为仅影响当前分支,因此如果您正在多个分支上积极开发,git push
不会再无意中推送与当前分支工作无关的其他工作; (c) 你将不需要专门命名远程和分支的 git push 形式,除非你试图推送到某个不是你当前分支的上游配置的分支——我认为这最有效感觉:如果你不是从本地分支推送到其自然的、配置的上游目标,你应该只需要详细地拼出分支。即使是 2.0 simple
设置也不能满足这一要求。
remote-name
通常是 origin
,但可以是任何配置的远程,通过各种 git 命令添加或直接在 .gitconfig 文件中添加。
关于git - git push origin development和git push origin HEAD :development的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36255366/
在git中,以下有什么区别? 头 头^ HEAD~1 HEAD~2 它们与 master 有什么关系?那么有没有MASTER^, MASTER~1?? 最佳答案 HEAD 是当前分支上最新提交的同义词
我想实现一个 LinkedListremove 方法,该方法可以删除任何特定位置的项目,但在本例中,我最感兴趣的是删除列表开头(第 0 个位置)的项目。 我的代码适用于 n 大于零的值,因此我为 n=
的顺序有什么关系吗?或 或 标签位于 中? (愚蠢的问题,但其中一件事我直到现在才考虑过。) 最佳答案 优化 据 Yahoo! 的人说你应该put CSS at the top和 scripts
HEAD 是指向当前分支的指针。我见过 HEAD 祖先的各种符号,包括 HEAD~2 HEAD^2 HEAD@{2} 头~~ 头^^ 以上每一项到底是什么意思?这方面的文件在哪里? 最佳答案 来自文档
我对 git 很陌生,任何人都可以帮助我。 我实际上被困在什么是“git diff HEAD”。 “git diff HEAD”和“git diff HEAD HEAD~1”有什么区别 最佳答案 gi
我似乎不知道如何获得 git_reference *到特定 Remote 的 HEAD。 我有: git_repository * repo = NULL; git_reference * ref
关于 firefox浏览器控制台,我可以访问 容器如下所示。 > window [object Window] > documentObject = window["document"
我使用 asp.net 4 和 c#。 我在 Web From 页面中有一个 Web 用户控件。当我包含 Web 用户控件时,我还想以编程方式在最终生成的页面的标记中包含一些脚本。 知道怎么做吗?也许
这可能是一个非常愚蠢的问题,但是加载文件中标签之间的数据并通过 PHP include() 加载它是愚蠢的吗?这样就可以更轻松地进行编辑。谢谢。 最佳答案 不,这不会是愚蠢的。代码重复越少越好。 关于
我编写了以下 facelet index.xhtml: 当我从浏览器获取
我有一个不断递增的“指针”,我需要最终返回指针的“头”。我进退两难,要么使用“pointer[0]”,要么使用另一个名为“head”的变量并初始化它并在最后返回。我觉得前者使代码看起来很脏,后来占用的
git push https://heroku:$HEROKU_API_KEY@git.heroku.com/$HEROKU_APP_NAME_PRODUCTION.git HEAD 和 git pu
当我像这样将 Git 子模块添加到 Git 存储库时, git submodule add ssh://server/proj1/ proj1 git submodule init git submo
我的本地存储库中有一个我不打算推送的提交(A)。现在,HEAD 在 A 处。假设我想在提交 (A) 之上创建另一个提交 (B) NOT,但在前一个提交之上而不是提交 (A)。 如何在不丢失最新
多次调用 head.load 是否同步? 我的意思是,如果我们有这样的代码: head.load('scr1.js',...,'scr8.js'); head.load('scr11.js',...,
执行以下查询时出现以下错误: #1054 - Unknown column 'headings.heading' in 'field list' 标题表中肯定有一个名为“标题”的列。当我测试它时,问题
我试图显示上次提交与之前提交之间的差异: git diff HEAD^ HEAD 但是什么都不显示。事实上,我知道这两个提交之间存在差异。 我做错了什么,我应该如何改正? P.S.:我觉得这个问题以
这就是场景。我有一个运行一些测试的脚本。我需要制作另一个接受 git 提交名称作为参数的脚本,然后执行以下操作: 保存当前提交状态 - 分支名称或未命名提交。 在指定提交时切换到分离的 HEAD 针对
我发现自己经常输入这个,比如当我做了一些改变,提交它,然后要么需要查找我在那里做的事情来弄清楚下一步该做什么,要么确保我没有添加任何意外的东西在将其推送到远程之前提交。 无可否认,diff HEAD^
我是否理解正确,Git head(小写)和 Git HEAD(大写)的区别在于前者是结束提交,后者只是当前提交(无论是最终提交还是非最终提交被选为 HEAD 提交)? 编辑:“结束提交”是指“给定分支
我是一名优秀的程序员,十分优秀!