【问题标题】:Simplify Xargs expression in git alias简化 git 别名中的 Xargs 表达式
【发布时间】:2014-11-11 00:24:24
【问题描述】:

我正在尝试创建一个 git 别名来批准 GitHub 上的拉取请求。此别名的主要功能是章鱼合并多个拉取请求的能力。

到目前为止我得到了什么(.gitconfig):

[alias]
    approve = "!f() { git fetch origin $(echo $@ | xargs -n 1 | xargs -I {} echo refs/pull/{}/head:gh-{} ) && git merge $(echo $@ | xargs -n 1 | xargs -I {} echo gh-{}) --edit --log;}; f"

它按预期工作,但是我想知道是否可以简化参数处理:

$(echo $@ | xargs -n 1 | xargs -I {} echo refs/pull/{}/head:gh-{} )

$(echo $@ | xargs -n 1 | xargs -I {} echo gh-{})

用法

$ git approve 1 2 3 # to approve pull requests #1, #2 and #3

输出

SHA-1: XXXX

* Merge branches 'gh-1' and 'gh-2'

* gh-1:
  fix 1

* gh-2:
  fix 2

【问题讨论】:

    标签: git github xargs pull-request git-alias


    【解决方案1】:

    如果你有 GNU Parallel,我认为这会起作用:

    approve = "!parallel -X -j1 'git fetch origin refs/pull/{}/head:gh-{} && git merge gh-{} --edit --log' ::: "
    

    所有新计算机都有多个内核,但大多数程序本质上是串行的,因此不会使用多个内核。然而,许多任务是极其可并行化的:

    • 对多个文件运行相同的程序
    • 为文件中的每一行运行相同的程序
    • 为文件中的每个块运行相同的程序

    GNU Parallel 是一种通用的并行化器,可以轻松地在同一台机器上或在您可以通过 ssh 访问的多台机器上并行运行作业。

    如果您想在 4 个 CPU 上运行 32 个不同的作业,那么并行化的直接方法是在每个 CPU 上运行 8 个作业:

    GNU Parallel 会在完成后生成一个新进程 - 保持 CPU 处于活动状态,从而节省时间:

    安装

    个人安装不需要 root 访问权限。这样做可以在 10 秒内完成:

    (wget -O - pi.dk/3 || curl pi.dk/3/ || fetch -o - http://pi.dk/3) | bash
    

    有关其他安装选项,请参阅http://git.savannah.gnu.org/cgit/parallel.git/tree/README

    了解详情

    查看更多示例:http://www.gnu.org/software/parallel/man.html

    观看介绍视频:https://www.youtube.com/playlist?list=PL284C9FF2488BC6D1

    浏览教程:http://www.gnu.org/software/parallel/parallel_tutorial.html

    注册电子邮件列表以获得支持:https://lists.gnu.org/mailman/listinfo/parallel

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-03-31
      • 1970-01-01
      • 1970-01-01
      • 2014-03-10
      • 2021-11-28
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多