python程序从命令行和git difftool工作正常,但死于外部差异

时间:2013-06-25 05:18:40

标签: python git git-diff

这是程序正常运行,它正在消亡但有充分理由(因为文件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运行,这样可以正常工作。但是,这对我来说还不够,因为我想对git log -p和类似的东西使用这个diff程序,所以我不需要提出一堆脆弱的脚本,而且我很习惯已经运行git log -p(但希望改进git输出)。

我可以告诉(显然)在第二种情况下python无法找到ipdb。我不确定让它发挥作用的缺失。如果有人能告诉我从python加载一个可以提供比import更多控制的模块的方法,我将不胜感激。也许是imp.find_module?如果有人知道Git正在做什么导致这种情况,我也会喜欢它。

我也知道git发送第二个和第七个args作为要比较的文件名(而不是第一个和第二个args);我的dmp_diff程序已经考虑到了这一点(它与当前的问题无关)。

1 个答案:

答案 0 :(得分: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。

相关问题