如果有多个 Git 存储库包含一个文件mergedriver.info
这个文件看起来总是这样:
<project name>
<repository name>
由 Git 合并驱动程序触发的脚本正在评估此文件:
mergedriverinfo="$(git cat-file -p HEAD:mergedriver.info)"
success=$?
if [[ "$success" == "0" ]]; then
log "Evaluating mergedriver.info"
PROJECT_KEY="$(sed -E 's/([^\s]+)\s+([^\s]+)/\1/' <<< $mergedriverinfo)"
REPO_SLUG="$(sed -E 's/([^\s]+)\s+([^\s]+)/\2/' <<< $mergedriverinfo)"
log "PROJECT_KEY=$PROJECT_KEY"
log "REPO_SLUG=$REPO_SLUG"
else
log "Unable to read mergedriver.info"
exit 1
fi
在这种情况下,我不理解 sed 的行为。
为此mergedriver.info
:
test
conflict-on-auto-merge
日志输出如下所示:
2017-07-20 11:05:51.747 PROJECT_KEY=test
2017-07-20 11:05:51.748 REPO_SLUG=tesconflict-on-auto-merge
起初我尝试使用 sed -n 1p/2p 和 head/tail -1 读取 mergedriver.info,但不幸的$(git cat-file -p HEAD:mergedriver.info)
是,运行此脚本的两个不同平台的输出不同:
平台一:
$ od -c <<< $(git cat-file -p HEAD:mergedriver.info)
0000000 t e s t \n c o n f l i c t - o n
0000020 - a u t o - m e r g e \n
0000034
平台二:
± od -c <<< $(git cat-file -p HEAD:mergedriver.info)
0000000 t e s t c o n f l i c t - o n
0000020 - a u t o - m e r g e \n
0000034
如何解决这个问题呢?