0

这是正常运行的程序,它正在死去,但有一个很好的理由(因为文件ab存在)。

% 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 程序已经说明了这一点(它与当前的问题无关)。

4

1 回答 1

0

感谢@ThomasFenzl 的提示,确实 git 正在运行 python 2.7.2,而从命令行运行的是 2.7.5。仍然不完全确定为什么它找不到 ipdb lib 目录,但它肯定是一个很好的起点。

显然,使用而#!/usr/bin/env python不是指定确切的python二进制路径(在我的系统上是规范的/usr/local/bin/python)导致它在从git运行时获取系统的原始python。

我认为我仍然需要回退到该/usr/bin/env python方法,因为我需要它的环境之一仅在我的用户目录中安装了 python。

于 2013-06-25T12:35:07.320 回答