[英]git alias for HEAD:refs/for/master
我正在配置Gerrit
,我想避免写:
git push gerrit HEAD:refs/for/master
我想写:
git push review
我确信它可以修改.git/config
但我不能让它工作。
我设置了两种不同的推送类型,评论和noreview:
评论:
git config remote.review.pushurl ssh://<GERRIT_HOST>:29418/<PROJECT_PATH>.git
git config remote.review.push refs/heads/*:refs/for/*
git push review # this will push your current branch up for review
绕过审查:
git config remote.noreview.pushurl ssh://<GERRIT_HOST>:29418/<PROJECT_PATH>.git
git config remote.noreview.push refs/heads/*
git push noreview # this will push your current branch up, bypassing review
请注意,项目所有者/ Gerrit管理员需要进行一些Gerrit项目更改,以便绕过审核。 我认为需要将“推送”权限添加到refs / *的项目中(除非您具体了解哪些分支允许绕过审核)。 但是,对于评论,已经设置了发布所需的权限。 换句话说,如果你的
git push gerrit HEAD:refs/for/master
工作,比上面的“审查”部分也应该工作,而不改变任何其他。
为什么不创建bash别名?
alias review="git push gerrit HEAD:refs/for/master"
现在你可以输入:
review
如果你想在多个 gerrit分支上工作,请检查我的bash助手: https : //github.com/tomwys/gerrit-bash-commands
你最好做的是别名中的Git scriptlet。 这样的东西基于'上游'分支工作,虽然我想稍微清理一下:
[alias]
pub = "!f() { git push -u ${1:-origin} HEAD:`git config branch.$(git name-rev --name-only HEAD).merge | sed -e 's@refs/heads/@refs/for/@'`; }; f"
这样,您只需键入:
git pub
它就像你打字一样:
git push -u origin HEAD:refs/for/master
要么
git push -u origin HEAD:refs/for/myremote-branch
对此的唯一要求是它只与Windows上的Git Bash shell兼容,或者与许多Linux shell中的一个兼容。
您可能也对git-review感兴趣,它不仅通过简单地提供以下内容来消除push
:
git review
......还可以让你做以下事情:
git review branchname
查看上面链接中的“使用”部分以获取更多信息。
如果你想允许直接推送到refs / heads /中的分支你只需在gerrit web gui中添加一个权限:
你完成了。
也许不完全是你想要的,但如果你:
gerrit
进行review
(使用git remote rename gerrit review
), git config push.default tracking
,和 git config branch.master.merge refs/for/master
, 然后你可以git push review
,你的主人将被推到refrit refs/for/master
on gerrit。
而且,顺便说一句,如果你git config branch.master.remote review
,那么你可以只是git push
并得到相同的东西。
那些想要通过gerrit只推送主分支的人,将以下内容添加到.git\\config
[remote "review"]
push = HEAD:refs/for/master
pushurl = ssh://GERRIT_URL:29418/PROJECT_NAME
或者在项目目录中执行
git config remote.review.push HEAD:refs/for/master
git config remote.review.pushurl ssh://GERRIT_URL:29418/PROJECT_NAME
然后你可以使用
git push review
推向格里特。 使用此方法,您可以从任何本地分支推送,数据将始终转到主分支
嗨,只需创建一个简单的脚本来自动化该过程:
#!/bin/bash
GROUP1_REVIEWER="group1 list of mail separated by space"
GROUP2_REVIEWER="group2 list of mail separated by space"
GROUP3_REVIEWER="group3 list of mail separated by space"
ORIGIN=$(git config --get remote.origin.url)
[ $? -ne 0 ] && echo "Git repo not found; EXIT" && exit 1
case $1 in
group1) REVIEWER_LIST=$GROUP1_REVIEWER ;;
group2) REVIEWER_LIST=$GROUP2_REVIEWER ;;
group3) REVIEWER_LIST=$GROUP3_REVIEWER ;;
*) echo "Please specify one existent group"; exit 1 ;;
esac
[ "$1" == "" ] && echo "Please specify one existent group" && exit 1
pushurl=${ORIGIN}
push="HEAD:refs/for/master"
receivepack="$(printf "git receive-pack "; for reviewer in $REVIEWER_LIST ; do printf -- "--reviewer $reviewer "; done)"
# check if review remote is already present
git config -l | grep remote.review 1>/dev/null 2>&1
[ $? -eq 0 ] && echo "Remote review already present; configure it manually; EXIT" && exit 1
# start config
echo "Adding new remote review config"
git config remote.review.pushurl $pushurl
git config remote.review.push $push
git config remote.review.receivepack "$receivepack"
您将使用:
git_review_add_config.sh group1
并选择您需要配置的不同组。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.