これは正常に実行されているプログラムです。死にかけていますが、正当な理由があります (ファイル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で外部差分を実行すると、これが得られます。それは悪い理由で死んでいます (46 行目ではなく 16 行目にしか到達していないことに注意してください):
% 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
ため、脆弱なスクリプトをたくさん考え出す必要はありません。また、git log の実行に非常に慣れています。 p は既にあります (ただし、git 出力の改善が必要です)。
(明らかに) 2 番目のケースでは、python が ipdb を見つけられないことがわかります。これを機能させるために何が欠けているのかわかりません。より多くの制御を提供できる Python からモジュールをロードする方法を誰かが教えてくれれば幸いですimport
。imp.find_module
、 多分?また、Git がこれを引き起こしている狂気を知っている人がいれば、私もそれが大好きです。
また、git が比較対象のファイル名を (1 番目と 2 番目の引数としてではなく) 2 番目と 7 番目の引数として送信することも認識しています。私の dmp_diff プログラムはすでにそれを説明しています (そして、この現在の問題とは何の関係もありません)。