- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试在 Windows 8.1 系统上的 Git Bash 中使用 KDiff3 作为 difftool,我承认我对 Git 很陌生。当我尝试将暂存文件与提交文件进行比较时,我无法打开 KDiff3,而且我对如何处理它感到困惑。我在网上找到了将 KDiff3 设置为 merge 工具的说明,我想我需要做一些类似的事情来将它设置为 diff 工具(我还没有能够为新手找到足够明确的指导来设置 diff 工具,这就是我来这里的原因)。这是我在下载并安装 KDiff3 后所做的:
git config --global diff.tool kdiff3
git config --global difftool.kdiff3.cmd '"C:\\Program Files\\KDiff3\\kdiff3" $BASE $LOCAL $REMOTE -o $MERGED'
Git 没有向我吐出任何错误,所以也许这是正确的?我完全承认我不明白这里的语法!无论如何,当我尝试这个时:
git diff HEAD
我明白了:
error: cannot spawn kdiff3: No such file or directory
external diff died, stopping at MyFile.R
我环顾四周,看到一些人在 $PATH 设置不正确时遇到了类似的问题。我真的不知道 $PATH 是什么(如果有人能启发我,我将非常感激),但我为 KDiff3 (C:\Program Files\KDiff3\kidff3) 获得的路径肯定是kdiff3.exe 在我的机器上的位置。有什么建议吗?
提前致谢,正如我所说,我是 Git 的新手,所以如果我没有提供一些重要信息,请告诉我。
最佳答案
我建议你放弃你的第二行配置,因为 Git bash 已经定义了如何使用 kdiff3。 (你可以看看你安装的Git Bash,比如我的路径下,可以找到C:\Program Files (x86)\Git\libexec\git-core\mergetools\kdiff3,就是kdiff3的配置文件) .您唯一需要做的就是将 kdiff3 放入您的 PATH 变量中。
只使用你的第一行:
git config --global diff.tool kdiff3
但不是你的第二行:
#### comment out this line:
# git config --global difftool.kdiff3.cmd '"C:\\Program Files\\KDiff3\\kdiff3" $BASE $LOCAL $REMOTE -o $MERGED'
要修复你已经添加的配置,请尝试在你的 GIT BASH 下编辑你的 .gitconfig
vim ~/.gitconfig
找到 [difftool "kdiff3"]
部分,然后删除该部分下带有 cmd=
的行。您也可以删除整个部分(即也删除包含 [difftool "kdiff3"]
然后将您的路径添加到 kdiff3:
PATH=$PATH:"/c/Program Files/KDiff3"
由于“程序”和"file"之间的空格,需要双引号。
此 PATH 行可以添加到您的 .bashrc 或 .bash_profile,具体取决于您启动 bash 的方式...
---更新---
更正:由于 Git Bash 使用 Windows 系统定义的环境变量“PATH”+ Windows 用户定义的环境变量“PATH”。上述 PATH 更改更难(使用 .bashrc 等)。只需更改 Windows 环境变量,如 this link , 和/或 this link
关于混帐庆典 : Can't spawn kdiff3 as difftool,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27262781/
我是 CAN 协议(protocol)的新手,正在阅读 Robert Bosch 的 CAN 规范 ver2.0 B 部分。我无法理解第 63 页上的以下几行 ”注意:启动/唤醒:如果在启动期间只有一
我用 C 写了一些代码来读取 CAN 总线数据。当我读取 11 位 CAN ID 时一切正常。一旦我尝试读取 29 位 ID,它就会错误地显示 ID。 示例: 接收29位ID的消息: 0x01F0A0
如果这看起来与另一个问题相似或者看起来已经得到回答,我提前道歉。我觉得它非常详细,足以证明自己的问题。 我正在尝试寻找一个虚拟的 CAN 总线模拟器(或一些可以轻松制作模拟器的方法),它只会生成 CA
我的问题涉及 GNU 的品牌。 如果您有一系列命令可用作多个目标的配方,则 canned recipe派上用场了。我可能看起来像这样: define run-foo # Here comes a #
您好,我是一名学习canopen的学生。Canopen中的COB-ID和CAN标识符有什么关系?我在CIA主页上看到COB-ID不是CAN ID,但我不明白。 例如,如果 PDO 通过 CAN 总线传
我知道一个显性确认位是由另一个节点传输的消息的接收器发送的。 我无法理解的是,接收方是在接收到整个消息后发送单个显性位,还是接收者发送相同的消息,其中 ACK 位字段为显性? 或者是接收器在发送器传输
我是 CAN 协议(protocol)的新手,我正在尝试通过 Linux 的 SocketCAN 使用它。然而,我对可用的 2 种不同的 CAN 套接字(RAW 和广播管理器 (BCM))感到困惑。
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我正在尝试制作一个在 Windows 下运行并与 ELM327 设备通信的软件。我创建了第一个版本,然后我进入了我的 SMART ForTwo (SMART 451) 车辆,我设法连接了仪表盘(发送
我知道在 CAN Controller 中,如果错误计数达到某个阈值(比如 255),就会发生总线关闭,这意味着特定的 CAN 节点将从 CAN 网络中关闭。所以根本不会有任何交流。但是,如果上述情况
我正在使用 ELM327,我希望能够设置要发送的 CAN 消息的 header 和数据部分。我看到有一个代码用于设置消息的标题 SH xxyyzz 但是我很难找出如何设置数据部分并控制何时发送消息。
我想做的是: 将数据插入具有两列的表中,并在同一 PHP 页面中显示更新的值。我能够获取数据并显示它,但无法插入任何数据。请指导我。 文件名为 mypage.php 到目前为止我的代码:
(这个问题是关于 Android 11 的) 我想将崩溃日志打印到其他应用程序可以读取的文件中(具体来说,我希望能够导航到该文件并使用"file"应用程序查看数据)。 我看过很多关于这个问题的答案,但
这会产生“ fatal error :无法解开Optional.None”,我似乎不明白为什么 var motionManager = CMMotionManager() motionManager.
在 Java 中,我经常遇到带有后缀 -able 的接口(interface),例如可序列化、可迭代等。这表明实现这些接口(interface)的对象具有可以对其执行某些操作的特性,例如该对象可以被序
我正在阅读 CanJS API 文档并遇到 can.Construct.extend http://canjs.com/docs/can.Construct.extend.html .我知道 can.
我正在使用 C 语言在 STM32F1xx 上进行开发,直到现在我都在尝试使用“CANopenNode-master”实现 CANopen 堆栈,并且我正在使用 2 个中断。 第一个是用于处理 SYN
我一直在使用 SocketCAN,尤其是 Virtual CAN vcan。但是,到目前为止,我从未使用过 CAN FD(灵活数据速率)。 好吧,我今天早上用 can-utils 试了一下: cans
我正在运行一个带有两个 CAN channel 的程序(使用 TowerTech CAN Cape TT3201)。 两个 channel 是 can0 (500k) 和 can1 (125k)。 c
存储由序列字符组成的字符串的 %s 格式说明符可以存储整数序列吗?如果是的话..你能解释一下吗? 最佳答案 无论如何,数字都是用字符表示的,所以是的,您可以使用 "%s" 说明符读取数字并将其存储在
我是一名优秀的程序员,十分优秀!