在我们的项目中,我们使用git提交信息来为提交添加某些元数据。最明显的是JIRA id,但还有其他的。
我正在尝试处理提交信息以提取这些数据并对其进行操作,但我遇到了问题,即如何针对每个消息而不是每行运行脚本。
例如,这就是我正在尝试做的事情:
但是这会导致我出现“xargs: gitLogExtractJIRA: 没有这个文件或目录”的错误。
我还研究了使用https://git-scm.com/docs/git-for-each-ref,尤其是--shell子命令,但认为在这种情况下不适用,因为我正在迭代日志消息而不是refs。虽然我很少使用for-each-ref,但我可能是错的。
所以我的问题是如何对每个git日志输出消息运行一个bash函数(或内联命令组),而不是每行运行一个?
# Extract JIRA issue ids for last 5 commits
git log --format=format:%B --no-merges -n5 | while read line ; do echo $line | grep -oP "(?<=JIRA: )[^ ]+"; done
#Output
456
128
756
在这种情况下,这确实有效,但问题是在此处使用while会按行而非按日志输出的一条消息运行grep太多次。当我尝试执行以下操作时,这就成为了一个问题:
# Extract JIRA issue id and Gerrit change id from last 5 commits
git log --format=format:%B --no-merges -n5 | while read line ; do echo $line | grep -oP "(?<=Change-Id: )[^ ]+|(?<=JIRA: )[^ ]+"; done
#Output
Ida3e220cdfa80ace5164109916fb5015d7aaaaaa
Ic4eed79f8acf5bf56f848bf543168e4ac9aaaaaa
456
I51dc621df6f54539f05053f6e036cc97a7aaaaaa
128
Ic04fa3de9b5e453358292bc7b965139707aaaaaa
756
I453a99155dacdc693ee28f248e92a6ccc8aaaaaa
正如您所看到的,grep中的每个匹配项都会被打印在不同的行上,但我希望以以下格式输出:
Change-Id JIRA
Ida3e220cdfa80ace5164109916fb5015d7aaaaaa
Ida3e220cdfa80ace5164109916fb5015d7aaaaaa 128
Ic04fa3de9b5e453358292bc7b965139707aaaaaa 756
请注意,有些提交没有Jira Id,这应该通过空字符串或“”来反映,就像第一个提交所示。
我还尝试使用
# Extract JIRA ids using bash function and xargs
git log --format=format:%B --no-merges -n5 | xargs -L1 gitLogExtractJIRA
但是这会导致我出现“xargs: gitLogExtractJIRA: 没有这个文件或目录”的错误。
我还研究了使用https://git-scm.com/docs/git-for-each-ref,尤其是--shell子命令,但认为在这种情况下不适用,因为我正在迭代日志消息而不是refs。虽然我很少使用for-each-ref,但我可能是错的。
所以我的问题是如何对每个git日志输出消息运行一个bash函数(或内联命令组),而不是每行运行一个?
xargs
将输入传递给命令,因此gitLogExtractJIRA
需要在您的上下文中可执行。 - l0b0xargs
调用函数。 - l0b0