首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >添加斜杠的git配置别名

添加斜杠的git配置别名
EN

Stack Overflow用户
提问于 2022-09-13 15:37:19
回答 1查看 36关注 0票数 0

我正在为一个加载别名创建一个安装脚本,而git配置没有很好地处理它们

下面是shell脚本中的命令

代码语言:javascript
复制
git config --global alias.sync-fork '"!f() { oldhash="$(git rev-parse -q --verify refs/stash)"; (git fetch --all && git stash --include-untracked) && ( (git checkout "$(git default-branch)" && git pull && git merge upstream/"$(git default-branch)" && git push && git checkout -); [ "$(git rev-parse -q --verify refs/stash)" != "$oldhash" ] || git stash pop) }; f"'

当我运行它并查看~/.gitconfig文件时,我在任何地方都可以看到"\",而且它不起作用。使用echo,我可以看到我想要的字符串。快把我逼疯了。

EN

Stack Overflow用户

回答已采纳

发布于 2022-09-13 15:49:47

最直接的问题是你有太多的引号;'"..."'应该是'...',而里面没有"。但是,我不能保证在你解决了那个问题之后,你不会有更多的问题。

不要试图手动转义shell函数,而是让shell本身为您使用declare -f来序列化函数。

代码语言:javascript
复制
f() {
  oldhash="$(git rev-parse -q --verify refs/stash)"
  (git fetch --all &&
   git stash --include-untracked
  ) && (
   (git checkout "$(git default-branch)" &&
    git pull &&
    git merge upstream/"$(git default-branch)" &&
    git push &&
    git checkout -)
   [ "$(git rev-parse -q --verify refs/stash)" != "$oldhash" ] || git stash pop)
}
git config --global alias.sync-fork '!'"$(declare -f f); f"

这确实意味着git将添加一些额外的转义符,以将函数配置为适当的配置文件形式,但是当您使用declare -f时,输出将保证格式良好(至少如果您的/bin/sh由bash提供)。

票数 2
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73705750

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档