python实现gerrit中四种下载patchset的方法(checkout,Cherry-pick,format-patch,pull)

 将patch打入本地repo,通常可以通过下面四种方法进行操作

Checkoutgit fetch https:xxxxxxx refs/changes/30/126030/2 && git checkout FETCH_HEAD

Cherry Pickgit fetch https:xxxxxxx refs/changes/30/126030/2 && git cherry-pick FETCH_HEAD

Format Patchgit fetch https:xxxxxxx refs/changes/30/126030/2 && git format-patch -1 --stdout FETCH_HEAD

Pullgit pull https:xxxxxxx refs/changes/30/126030/2

其中

cherry-pick: 在本地HEAD的基础上,加上commit的内容,并生成新的commitid。

checkout: checkout到commit时的状态,如果该commit patch后有新的commit 被merge,不会体现。此时分支名为(HEAD detached at FETCH_HEAD)

pull: 相当于git fetch https:xxxxxxx refs/changes/30/126030/2 && git merge FETCH_HEAD

 

工作中需要使用python实现gerrit patch set打入本地repo,实现方法有:

repo_path = /home/liurizhou/repo/test
git_repo = git.Repo(repo_path)
# checkout,Cherry-pick,format-patch 的实现方法,以checkout为例
git_repo.git.fetch('https:xxxxxxx', 'refs/changes/30/126030/2')
git_repo.git.checkout('FETCH_HEAD')
#pull 的实现方法
o = git_repo.remotes.origin
o.pull('refs/changes/30/126030/2')

 

 

  • 2
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值