我认为这个问题对于shell脚本怪物来说相当容易.
我正在寻找通过bash shell脚本创建Unix共享库的符号链接的最优雅和最短的方法.
我需要的是从一个共享库文件列表开始,如“libmythings.so.1.1,libotherthings.so.5.11”,获取创建的符号链接,如:
libmythings.so -> libmythings.so.1 -> libmythings.so.1.1
libotherthings.so -> libotherthings.so.5 -> libotherthings.so.5.11
编辑:嗯,“ldconfig -nN.”可以正常工作,但是我还需要在“.so”后面没有附加主要编号的链接,至少有一个库,因为一个或多个库是来自Java的JNI调用的入口点,所以当一个库通过System.loadlibrary(“libraryname”)实例化它需要一个名为“libraryname.so”的库,而不是“libraryname.so.X”.
最佳答案
for baselib in "$@"
do
shortlib=$baselib
while extn=$(echo $shortlib | sed 's/\.[0-9][0-9]*$//')
[ -n "$extn" ]
do
shortlib=$(basename $shortlib $extn)
ln -s $baselib $shortlib
done
done
我被骗了 – 所有的链接都去了基础库(libmythings.so.1.1);如果你真的想要连锁,那么你需要:
for baselib in "$@"
do
shortlib=$baselib
while extn=$(echo $shortlib | sed 's/\.[0-9][0-9]*$//')
[ -n "$extn" ]
do
shorterlib=$(basename $shortlib $extn)
ln -s $shortlib $shorterlib
shortlib=$shorterlib
done
done
当心 – 未经测试的代码.
傲慢在克星之前.
评论到达,上面的代码不起作用 – 评论是正确的.具有原位测试的固定版本是:
set -- libname.so.5.1.1
for baselib in "$@"
do
shortlib=$baselib
while extn=$(echo $shortlib | sed -n '/\.[0-9][0-9]*$/s/.*\(\.[0-9][0-9]*\)$/\1/p')
[ -n "$extn" ]
do
shortlib=$(basename $shortlib $extn)
echo ln -s $baselib $shortlib
done
done
更改位于sed命令中.此版本默认情况下不打印任何内容(-n),仅匹配以点后跟数字结尾的行,然后删除除该后缀之外的所有内容,并打印剩余的赋值给extn.修改后,脚本会生成以下输出.删除echo以使其执行链接命令.
ln -s libname.so.5.1.1 libname.so.5.1
ln -s libname.so.5.1.1 libname.so.5
ln -s libname.so.5.1.1 libname.so
该脚本说明了关于shell脚本的一个有趣且经常被忽略的观点:一段时间的条件块中的操作序列不必是单个命令.具有编辑操作的行的状态不会影响整个测试是否成功;最后一个命令的退出状态'[ – n“$extn”]’控制循环是否继续.