最近在虚拟机中编译ffmpeg源码时候遇到了这个问题:ln: failed to create symbolic link ‘libavutil.so’: Operation not supported
这个问题主要原因是在使用ln创建软连接时候失败了,因为这个文件系统是NTFS,windows上的,通过虚拟机挂载到linux上,所以并不支持ln操作。
之前在网上搜索,发现只有两个方法,一个是先把代码拷贝到linux中再编译,坏处是不能在win中修改代码后直接编译,第二种也是先把代码拷贝到linux系统中,只不过通过smb挂载到win中,就可以修改完直接编译了。
不过我觉得两个方法都挺麻烦的,整了一个第三方案:
先执行:
mv /bin/ln /bin/ln_ori
然后vi ln.cpp,写下如下代码:
#include <stdio.h>
#include <stdlib.h>
#include <string>
int main(int argc, char *argv[])
{
std::string cmd("/bin/ln_ori");
for (int i = 1; i < argc; i++)
{
cmd += " ";
cmd += argv[i];
}
printf("%s\n", cmd.c_str());
system(cmd.c_str());
return 0;
}
然后编译
make ln;cp ln /bin/ln
然后就可以继续编译了,因为Makefile在执行过程中,如果遇到一个操作失败就会整个退出,所以通过自己封装一个ln,来忽略失败的返回码,就能保证Makefile继续执行,这里加上了一个cmd的打印,为了之后手动ln
可能大家在继续make时候还会遇到链接错误,这个时候只要将对应的so文件的软连接放在/usr/lib/下面即可
还有一种python写法,直接把so文件copy到/usr/lib下面
这里的‘/mnt/hgfs/E/github/others/ffmpeg’需要改为执行make的目录位置
#!/usr/bin/python
import sys
import os
def cp():
argLen = len(sys.argv)
src = sys.argv[argLen - 2]
dst = '/usr/lib/' + sys.argv[argLen - 1]
cmd = 'cp %s %s' % (src, dst)
print cmd
os.system(cmd)
if __name__ == '__main__':
cmdStr = '/bin/ln_ori'
for i in range(1, len(sys.argv), 1):
cmdStr += ' ' + sys.argv[i]
print cmdStr
curcwd = os.getcwd()
if curcwd.startswith('/mnt/hgfs/E/github/others/ffmpeg'):
cp()
else:
os.system(cmdStr)