- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
如何通过单个命令获取有关 gerrit 更改的最新 refspec。我需要输出为“refs/changes/11/1234/4”。是否有相同的 git 命令
我知道结合 gerrit 查询和一些脚本的 ssh 命令可以获得这个,但想知道是否有更好的方法来做同样的事情。以下是我用来获取 refspec 的 ssh 命令。
ssh -p $REVIEW_SERVER_PORT $GERRIT_REVIEW_SERVER gerrit 查询 --format=TEXT --current-patch-set $CHANGE_SHA | grep 引用
同样,我也想获得 gerrit 更改的最新补丁集
最佳答案
你应该使用 gerrit query .给定更改编号 4665
:
ssh -p 29418 review.example.com gerrit query --current-patch-set --format=JSON change:4665
哪些输出:
{
"project":"xx",
"branch":"master",
"topic":"TOPIC",
"id":"I0b6fc492fd08749e409c359a73d74e7795f50cc9",
"number":"4665",
// ...
"currentPatchSet":{
"number":"5",
"revision":"ae3a5d2684991070041e1c34b5a16b1376dc3ce5",
"parents":[
"5b21793cadd3dc55008ef6c8dc658e127d80c097"
],
"ref":"refs/changes/65/4665/5",
// ...
}
}
在哪里可以找到 currentPatchSet.ref
字段。
旧的、过于复杂的解决方案:
前提是你想获取最新的patchset of change 2392
:
git ls-remote | grep /2392/ | awk '{print $2}' | sed 's/\// /g' | sort -n -k5 | tail -n 1 | sed 's/ /\//g'
为我的代码库输出 refs/changes/92/2392/12
。
或者,当您想要从 Gerrit 获取最后的更改时:
git ls-remote | awk '{print $2}' | sed 's/\// /g' | sort -n -k4 | tail -n 1 | sed 's/ /\//g'
为我的代码库输出 refs/changes/54/2554/2
。
解释
git ls-remote命令显示远程存储库中的所有引用,因此对于 Gerrit - 每个补丁集也会列出。它输出如下内容:
2ccddbfb34a98e8ba461964fae3766aa41be944d refs/changes/91/2291/7
d00c21c28d07626caea27594489442696ea39231 refs/changes/91/2291/8
8c05e6551a6a34c33a36669bf7e83c996569e24d refs/changes/91/2291/9
bc6762ac7b9ac5a74fc2e548df2541cb83977ec5 refs/changes/91/2391/1
3bd96c0d1ba2d561fa484ddfc264fabbf86aa536 refs/changes/91/2391/2
因此,为了从特定更改中选择所有补丁集,我们需要通过 /NUMBER/
grep 结果,这解释了 grep/2392/
。之后,通过使用 awk 选择第二列,结果为:
refs/changes/92/2392/1
refs/changes/92/2392/10
refs/changes/92/2392/11
refs/changes/92/2392/12
refs/changes/92/2392/2
refs/changes/92/2392/3
refs/changes/92/2392/4
refs/changes/92/2392/5
refs/changes/92/2392/6
refs/changes/92/2392/7
refs/changes/92/2392/8
refs/changes/92/2392/9
现在我们要选择最后一个补丁集。我们需要分类。 sort命令能够使用 -n
按数字排序,我们可以使用 -kX
参数指定要在哪一列上执行排序。但它需要用空格分隔列(AFAIK),所以我们需要用空格替换我们的 /
分隔符。我们使用 sed为了它。第一次替换后,每个 refs/changes/92/2392/X
变为 refs changes 92 2392 X
。然后对第五列(补丁集编号)执行排序。结果:
refs changes 92 2392 1
refs changes 92 2392 2
refs changes 92 2392 3
refs changes 92 2392 4
refs changes 92 2392 5
refs changes 92 2392 6
refs changes 92 2392 7
refs changes 92 2392 8
refs changes 92 2392 9
refs changes 92 2392 10
refs changes 92 2392 11
refs changes 92 2392 12
最后要做的是用 tail 选择最后一行并将空格替换回斜线。瞧!
以相同的方式从 Gerrit 中选择最新更改,但不使用 grep 并按第四列 (Change-Id) 排序。
关于git - 获取有关 Gerrit 更改的最新 refspec,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22264533/
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
ECharts是一个纯Javascript的图表库,可以流畅的运行在PC和移动设备上,兼容当前绝大部分浏览器,底层依赖轻量级的Canvas类库ZRender,提供直观、生动、可交互、可高度个性化定制
前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。 提示:以下是本篇文章正文
作为一名ios开发攻城狮,在苹果没有出arc(自动内存管理机制)时,我们几乎有一半的开发时间都耗费在这么管理内存上.后来苹果很人性的出了arc,虽然在很大程度上,帮助我们开发者节省了精力和时间.但是
如何反转Pandas中DataSeries的排序顺序,以便我按降序使用它们? 最佳答案 In [28]: s = pd.Series([20, 10, 30], ['c', 'a', 'b']) In
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Is jQuery $.browser Deprecated? 最新的 jQuery 库是否发生变化 $.brows
我正在开发一个 Intranet 项目,所以我无法复制/粘贴代码,所以希望我的描述和一些小片段会有所帮助。 我知道 MySQL 触发器无法做到这一点,但希望有一种干净的 JPA PrePersist(
这是数据集: 人员状态日期 埃里克 1 1/1/2015 埃里克 2 2/1/2015 埃里克 3 2015 年 3 月 1 日 约翰福音 1 3/1/2015 约翰福音 2 2015 年 2 月 1
现在我正在使用下面的查询按每篇文章的 auto_increment id 排序 mysql_query("SELECT * FROM articles ORDER BY id DESC"); 我想知道
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
现在我正在使用下面的查询按每篇文章的 auto_increment id 排序 mysql_query("SELECT * FROM articles ORDER BY id DESC"); 我想知道
在我们做文章的时候常用一些函数修改来实现自己的页面效果,例如,时间的自定义格式 我们常常需要乃至的,搜集了些有关时间格式的CODE,作大家为参考,希望对大家有些帮助 列表页list_article
我想将某些东西提交到 github 存储库,但我(显然)没有任何权利这样做。我对那个 repo 做了一个分支,提交了我的更改并提交了一个 pull-request。 现在,问题是过了一段时间其他人已经
我是 SQL 新手,所以现有的答案对我来说有点复杂。 我有三张 table : WORKER |id |name |date |... JOB |id |name |salary |accept AP
我正在自动从PowerPoint和Excel电子表格中生成PowerPoint报表。在粘贴表格之前,我已经完成了整个过程。 我使用PPApp.CommandBars.ExecuteMso ("Past
我们有 1 个 Kafka 主题和 1 个分区: 从 spring boot kafka 消费者那里看到一个相当奇怪的行为。 Spring kafka消费者在重新启动时总是从主题的开头开始消费。 我已
通过编程从iOS照片库获取最新照片是否有技巧? 我知道我可以按日期搜索,但是我必须每隔一微秒进行一次扫描,以便进行某种比较以准确地找到它。 有没有人做过这个或任何想法? 最佳答案 我之前采取的一种方法
我们上周将 Web 应用程序中的 Telerik Kendo 库从 V2015.2.902 升级到 V2016.1.112。从那时起,我们注意到使用 Kendo 的页面需要很长时间才能加载(30 秒到
我有两个表: STUDENT GRADES ---------- ---------- id id name person_id ad
我是一名优秀的程序员,十分优秀!