这是正常运行的程序,它正在死去,但有一个很好的理由(因为文件a
不b
存在)。
% dmp_diff a b
{'LESS': '-R', 'LC_CTYPE': 'en_US.UTF-8', 'SHELL': '/usr/local/bin/zsh', 'LOGNAME': 'lust', 'USER': 'lust', 'HOME
': '/Users/lust', 'PATH': '/Users/lust/bin:/Users/lust/util:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/loc
al/share/python:/opt/X11/bin:/Users/lust/bin:/Users/lust/util:/usr/local/share/npm/bin:/usr/local/share/npm/bin',
'DISPLAY': '/tmp/launch-uW8956/org.macosforge.xquartz:0', 'TERM_PROGRAM': 'iTerm.app', 'LANG': 'en_US.UTF-8', 'T
ERM': 'xterm-256color-italic', 'Apple_PubSub_Socket_Render': '/tmp/launch-rPIGNa/Render', 'SHLVL': '2', 'SECURITY
SESSIONID': '186a4', 'ITERM_SESSION_ID': 'w0t0p0', '_': '/Users/lust/util/dmp_diff', 'GREP_COLOR': '1;32', 'SSH_A
UTH_SOCK': '/tmp/launch-pgXEyS/Listeners', 'TMUX': '/private/var/folders/z_/ybb_x1f96l9d2yqr18ncmg1w0000gn/T/tmux
-501/default,19104,0', 'GREP_OPTIONS': '--color=auto', 'ITERM_PROFILE': 'Default', 'TMPDIR': '/var/folders/z_/ybb
_x1f96l9d2yqr18ncmg1w0000gn/T/', 'LSCOLORS': 'Gxfxcxdxbxegedabagacad', 'OLDPWD': '/Users/lust', '__CF_USER_TEXT_E
NCODING': '0x1F5:0:0', 'Apple_Ubiquity_Message': '/tmp/launch-V9NNsf/Apple_Ubiquity_Message', 'PWD': '/Users/lust
/.vim', 'PAGER': 'less', 'TMUX_PANE': '%10', 'COMMAND_MODE': 'unix2003'}
Files: a b
Traceback (most recent call last):
File "/Users/lust/util/dmp_diff", line 46, in <module>
file_content = open(filename, 'r').read()
IOError: [Errno 2] No such file or directory: 'a'
> /Users/lust/util/dmp_diff(46)<module>()
45 file_process = Popen(['file', '-'], stdin=PIPE, stdout=PIPE)
---> 46 file_content = open(filename, 'r').read()
47 file_content = map(lambda x: x.encode('string_escape')
ipdb>
与
[diff]
external = dmp_diff
当我用 git 运行外部差异时,我得到了这个;它死于一个不好的原因(注意它只到了第 16 行而不是第 46 行):
% git diff
{'LESS': '-R', 'GIT_PAGER_IN_USE': 'true', 'VERSIONER_PYTHON_PREFER_32_BIT': 'no', 'LC_CTYPE': 'en_US.UTF-8', 'SH
ELL': '/usr/local/bin/zsh', 'LOGNAME': 'lust', 'USER': 'lust', 'HOME': '/Users/lust', 'PATH': '/usr/libexec/git-c
ore:/usr/bin:/Users/lust/bin:/Users/lust/util:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/share/pytho
n:/opt/X11/bin:/Users/lust/bin:/Users/lust/util:/usr/local/share/npm/bin:/usr/local/share/npm/bin', 'DISPLAY': '/
tmp/launch-uW8956/org.macosforge.xquartz:0', 'TERM_PROGRAM': 'iTerm.app', 'LANG': 'en_US.UTF-8', 'GIT_PREFIX': ''
, 'TERM': 'xterm-256color-italic', 'Apple_PubSub_Socket_Render': '/tmp/launch-rPIGNa/Render', 'VERSIONER_PYTHON_V
ERSION': '2.7', 'SHLVL': '2', 'SECURITYSESSIONID': '186a4', 'ITERM_SESSION_ID': 'w0t0p0', '_': '/usr/bin/git', 'G
REP_COLOR': '1;32', 'SSH_AUTH_SOCK': '/tmp/launch-pgXEyS/Listeners', 'TMUX': '/private/var/folders/z_/ybb_x1f96l9
d2yqr18ncmg1w0000gn/T/tmux-501/default,19104,0', 'GREP_OPTIONS': '--color=auto', 'ITERM_PROFILE': 'Default', 'TMP
DIR': '/var/folders/z_/ybb_x1f96l9d2yqr18ncmg1w0000gn/T/', 'LSCOLORS': 'Gxfxcxdxbxegedabagacad', 'OLDPWD': '/User
s/lust/util/.git', '__CF_USER_TEXT_ENCODING': '0x1F5:0:0', 'Apple_Ubiquity_Message': '/tmp/launch-V9NNsf/Apple_Ub
iquity_Message', 'PWD': '/Users/lust/util', 'GIT_DIR': '.git', 'PAGER': 'less', 'TMUX_PANE': '%9', 'COMMAND_MODE'
: 'unix2003'}
Traceback (most recent call last):
File "/Users/lust/util/dmp_diff", line 16, in <module>
import ipdb
ImportError: No module named ipdb
external diff died, stopping at .dmp_diff.un~.
(END)
现在,如果我将 dmp_diff 作为 git 运行,这可以正常工作difftool
。然而,这对我来说还不够,因为我想用这个 diff 程序git log -p
来做类似的事情,这样我就不需要想出一堆脆弱的脚本,而且我非常习惯于运行 git log - p 已经(但想要改进的 git 输出)。
我可以说(显然)在第二种情况下,python 无法找到 ipdb。我不确定要使它正常工作缺少什么。如果有人能告诉我如何从 python 加载一个可以提供比import
. imp.find_module
, 也许?如果有人知道 Git 正在做什么疯狂导致这种情况,我也会喜欢它。
我也知道 git 将要比较的文件名作为第二个和第七个参数发送(而不是作为第一个和第二个参数);我的 dmp_diff 程序已经说明了这一点(它与当前的问题无关)。