如何处理git别名的组合 以前的尝试

问题描述

问题

我在.gitconfig中定义了三个git别名(使用外部bash脚本定义了称为diff-lines的函数):

<%= form_with(model: project,:html => {:id => 'project-form-validation'},local: true) do |form| %>

<div class="row select-date-wrapper">
  <div class="field columns large-6">
    <%= form.label :project_name,:class=>"required" %>
    <%= form.text_field :project_name %>
  </div>

  <div class="field columns large-2">
    <%= form.label :from_date,:class=>"required" %>
    <%= form.text_field :from_date,class: 'datepicker',readonly: 'true' %>
  </div>

  <div class="field columns large-1"></div>

  <div class="field columns large-2">
    <%= form.label :to_date,:class=>"required" %>
    <%= form.text_field :to_date,readonly: 'true' %>
  </div>

  <div class="field columns large-1"></div>
</div>

<div class="row">
  <div class="actions columns button-right">
    <br>
    <%= form.submit :class => "button primary" %>
  </div>
</div>
<% end %>

如何定义'diffln',以便可以告诉我要使用的diff别名的版本?

我正在寻找某种方法来防止我必须定义类似于以下内容的每个版本:

    [alias]
        diffc = diff --cached
        diffnw = diff -w --ignore-cr-at-eol --ignore-all-space
        diffln =!bash -c 'source $HOME/.bash_functions/diff-lines && git diff | diff-lines'

解决方案

感谢@KamilCuk提供解决方案。我需要在别名后面添加一些内容/东西,还要将整个别名用双引号引起来。

完整的工作命令是这样(如果没有提供参数,默认选项是使用git diff):

    diffcln =!bash -c 'source $HOME/.bash_functions/diff-lines && git diffc | diff-lines'
    diffnwln =!bash -c 'source $HOME/.bash_functions/diff-lines && git diffnw | diff-lines'
    diffcnwln =!bash -c 'source $HOME/.bash_functions/diff-lines && git diffnw --cached | diff-lines'
    etc...

以前的尝试

我已经尝试过了:
diffln ="!bash -c 'source $HOME/.bash_functions/diff-lines && if ((!$#)); then set -- diff; fi && git $@ | diff-lines' _"
并通过以下方式调用:
diffln =!bash -c 'source $HOME/.bash_functions/diff-lines && git $@ | diff-lines' 但这给了我默认的git选项,就好像我只是打电话给$ git diffln diffc

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)