1、sudo apt-get install meld
2、安装完毕后,设置~/.subversion/config中,diff-cmd = meld
使用svn diff的时候出现了
……
File "/usr/lib/python2.7/multiprocessing/connection.py", line 39, in
<module>
import socket
ImportError: /usr/bin/socket.so: undefined symbol: lua_gettop
搜索后发现,是因为Python的模块加载问题,如果在其其搜索目录下存在socket.py/socket.so/socket.dll(或许只要是可执行的socket.*都会默认加载)
且此路径在python的安装路径之前,那么会先加载已经搜索到的socket文件,造成import socket错误。
(关于详细解释在 http://blog.chinaunix.net/uid-20788636-id-4223417.html)
由于python会优先搜索执行文件的当前路径,然后搜索其安装路径,测试如下。
测试代码:
#!/usr/bin/env python
# coding=utf-8
import sys,pprint
pprint.pprint(sys.path)
输出结果:
['/home/***/python/test',
'/usr/lib/python2.7',
'/usr/lib/python2.7/plat-i386-linux-gnu',
'/usr/lib/python2.7/lib-tk',
'/usr/lib/python2.7/lib-old',
'/usr/lib/python2.7/lib-dynload',
'/usr/local/lib/python2.7/dist-packages',
'/usr/lib/python2.7/dist-packages',
'/usr/lib/python2.7/dist-packages/PILcompat',
'/usr/lib/python2.7/dist-packages/gtk-2.0',
'/usr/lib/pymodules/python2.7',
'/usr/lib/python2.7/dist-packages/ubuntu-sso-client']
如果当前执行路径存在socket.*的可执行文件,就出现错误。
同理,当遇到其他importError的时候,也是这样的错误。
所以,在使用python编程的时候,python文件的命名要慎重,避免与python的固有module相同,造成不必要的麻烦。
最终这里解决meld可用的方式是,
将meld移到其他文件夹下,
配置diff-cmd的时候使用绝对路径。
即:diff-cmd = /usr/lib/meld/meld/meld