我使用以下命令推送到远程分支:

git push origin sandbox

如果我说

git push origin

这是在我的其他分支中也推送更改,还是只更新我的当前分支?我有三个分支:master、production和sandbox。

git推送文档对此不是很清楚,所以我想永远澄清这一点。

下面的git push命令会准确更新哪些分支和远程?

git push 
git push origin

上面的原点是一个遥控器。

我知道gitpush[remote][branch]将只将该分支推送到远程。


当前回答

您可以在.gitconfig中更改默认行为,例如:

[push]
  default = current

要检查当前设置,请运行:

git config --global --get push.default

其他回答

git 2.37.0中的新配置

运行以设置自动设置远程,而不是更改推送默认行为

git config --global --add --bool push.autoSetupRemote true

它与push配合得很好。默认为简单的上游

参考文献:答案推特文档犯罪

(2012年3月)注意:默认的“匹配”策略可能很快就会改变(有时在git1.7.10+之后):

请参阅“请讨论:当你不说推送什么时,“git推送”应该做什么?”

在当前设置中(即push.default=matching),不带参数的gitpush将推送本地和远程存在的同名分支。当开发人员将其推送到自己的公共存储库时,这通常是合适的,但在使用共享存储库时如果不是危险的话,可能会令人困惑。建议将默认值更改为“上游”,即仅推送当前分支,并将其推送到git pull将从中拉出的分支。另一位候选人是“现任”;这只将当前分支推送到同名的远程分支。到目前为止讨论的内容可以在本主题中看到:

http://thread.gmane.org/gmane.comp.version-control.git/192547/focus=192694

之前的相关讨论包括:

http://thread.gmane.org/gmane.comp.version-control.git/123350/focus=123541http://thread.gmane.org/gmane.comp.version-control.git/166743

要加入讨论,请将消息发送到:git@vger.kernel.org

与使用别名相比,我更喜欢创建git XXX脚本,这样我可以更容易地对它们进行源代码控制(我们的开发人员都在其路径上有一个特定的源代码控制目录)。

此脚本(称为gitsetpush)将remote.origin.push值的配置值设置为仅推送当前分支的值:

#!/bin/bash -eu

CURRENT_BRANCH=$(git branch | grep '^\*' | cut -d" " -f2)
NEW_PUSH_REF=HEAD:refs/for/$CURRENT_BRANCH

echo "setting remote.origin.push to $NEW_PUSH_REF"
git config remote.origin.push $NEW_PUSH_REF

注意,当我们使用Gerrit时,它将目标设置为refs/for/XXX,以将其推入审查分支。它还假定源是您的远程名称。

使用签出分支后调用

git checkout your-branch
git setpush

很明显,它也可以用来结账,但我喜欢脚本做一件事,并且做得很好

您可以在.gitconfig中更改默认行为,例如:

[push]
  default = current

要检查当前设置,请运行:

git config --global --get push.default

我在.bashrc文件中添加了以下函数,以自动化这些任务。它执行gitpush/gitpull+当前分支的名称。

function gpush()
{
  if [[ "x$1" == "x-h" ]]; then
    cat <<EOF
Usage: gpush
git: for current branch: push changes to remote branch;
EOF
  else
    set -x
    local bname=`git rev-parse --abbrev-ref --symbolic-full-name @{u} | sed -e "s#/# #"`
    git push ${bname}
    set +x
  fi
}

function gpull()
{
  if [[ "x$1" == "x-h" ]]; then
    cat <<EOF
Usage: gpull
git: for current branch: pull changes from
EOF
  else
    set -x
    local bname=`git rev-parse --abbrev-ref --symbolic-full-name @{u} | sed -e "s#/# #"`
    git pull ${bname}
    set +x
  fi
}