AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 406946
Accepted
Martin Vegter
Martin Vegter
Asked: 2017-11-26 02:05:08 +0800 CST2017-11-26 02:05:08 +0800 CST 2017-11-26 02:05:08 +0800 CST

git:仅在 GUI 中使用视觉差异(融合)

  • 772

我知道我可以指定要用于的外部 diff 命令git diff:

[diff]
    external = 

但是当我登录控制台(没有X)时,这会失败,因为我的视觉差异无法打开显示(显然)

我如何告诉 git 仅在登录 GUI/X 时才使用视觉差异?

diff git
  • 2 2 个回答
  • 595 Views

2 个回答

  • Voted
  1. Mats Wichmann
    2017-11-29T06:48:51+08:002017-11-29T06:48:51+08:00

    有几种简单的方法可以做到这一点......要在“外部”git 执行它,您可以将您的 difftool 程序(您可能需要 difftool 而不是 diff 来启动视觉差异)设置为一个包装脚本,以确定您是否是是否在图形环境中并启动适当的程序;或“内部”git,您可以执行一些特定于环境的条件包含(includeIf)。

    • 3
  2. Best Answer
    Arkadiusz Drabczyk
    2017-12-01T12:11:42+08:002017-12-01T12:11:42+08:00

    您要求,an answer drawing from credible and/or official sources所以我将在此答案中引用一些官方文档。

    首先,我们需要找到一种方法来确定我们是否在X 会话内部运行。例如,我们可以通过检查是否$DISPLAY 设置了变量来做到这一点。如中所述man X:

    展示

    这是唯一的强制环境变量。它必须指向 X 服务器。请参阅上面的“显示名称”部分。

    但是,这可能不是一个好主意,因为 DISPLAY即使在X. 在这个答案中提出了一个更好的方法:

    if xhost >& /dev/null ; then echo "Display exists"
    else echo "Display invalid" ; fi
    

    你应该已经在你的机器上安装了一个名为的程序xhost,确保你有它:

    $ type -a xhost
    xhost is /usr/bin/xhost
    

    现在,我们可以设置diff.external指向一个包装器,如果我们在里面,它将调用外部差异,如果我们不在里面X,则运行默认 git diff机制X。不幸的是,我无法想出一种简单的方法来运行默认值git diff, diff.external所以让我们改为创建一个别名来git临时diff.external使用-c. 如中所述man git:

    -c <名称>=<值>

    将配置参数传递给命令。给定的值将覆盖配置文件中的值。预期的格式与 git config 列出的格式相同(子键以点分隔)。

    请注意,在 git -c foo.bar ... 中省略 = 是允许的,并将 foo.bar 设置为布尔真值(就像 [foo]bar 在配置文件中一样)。包括等于但具有空值(如 git -c foo.bar= ...)将 foo.bar 设置为空字符串。

    它会是这样的:

    $ git -c diff.external=diff-wrapper.sh ...
    

    总结一下:

    • 创建一个名为的脚本~/git-wrapper.sh并替换 <YOUR_DIFF_WRAPPER>为您想要的任何内容:

      #!/usr/bin/env sh
      
      if xhost >/dev/null 2>&1
      then
          git -c diff.external=<YOUR_DIFF_WRAPPER>  "$@"
      else
          git "$@"
      fi
      
    • 设置一个可执行位:

       $ chmod +x ~/git-wrapper.sh
      
    • 在您的 shell 启动文件中设置别名,例如~/.bashrc并重新加载 shell:

       alias git=~/git-wrapper.sh
      
    • 正常使用git:

       $ git diff
      

      <YOUR_DIFF_WRAPPER>如果您在里面X,它将使用它,并将git-diff在X.

    • 2

相关问题

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    JSON数组使用jq来bash变量

    • 4 个回答
  • Marko Smith

    日期可以为 GMT 时区格式化当前时间吗?[复制]

    • 2 个回答
  • Marko Smith

    bash + 通过 bash 脚本从文件中读取变量和值

    • 4 个回答
  • Marko Smith

    如何复制目录并在同一命令中重命名它?

    • 4 个回答
  • Marko Smith

    ssh 连接。X11 连接因身份验证错误而被拒绝

    • 3 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Marko Smith

    systemctl 命令在 RHEL 6 中不起作用

    • 3 个回答
  • Marko Smith

    rsync 端口 22 和 873 使用

    • 2 个回答
  • Marko Smith

    以 100% 的利用率捕捉 /dev/loop -- 没有可用空间

    • 1 个回答
  • Marko Smith

    jq 打印子对象中所有的键和值

    • 2 个回答
  • Martin Hope
    EHerman JSON数组使用jq来bash变量 2017-12-31 14:50:58 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Drux 日期可以为 GMT 时区格式化当前时间吗?[复制] 2017-12-26 11:35:07 +0800 CST
  • Martin Hope
    AllisonC 如何复制目录并在同一命令中重命名它? 2017-12-22 05:28:06 +0800 CST
  • Martin Hope
    Steve “root”用户的文件权限如何工作? 2017-12-22 02:46:01 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST
  • Martin Hope
    Cbhihe 将默认编辑器更改为 vim for _ sudo systemctl edit [unit-file] _ 2017-12-03 10:11:38 +0800 CST
  • Martin Hope
    showkey 如何下载软件包而不是使用 apt-get 命令安装它? 2017-12-03 02:15:02 +0800 CST
  • Martin Hope
    youxiao 为什么目录 /home、/usr、/var 等都具有相同的 inode 编号 (2)? 2017-12-02 05:33:41 +0800 CST
  • Martin Hope
    user223600 gpg —list-keys 命令在将私钥导入全新安装后输出 uid [未知] 2017-11-26 18:26:02 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve