在macOS中,如果我们想把一个本地的动态链接库(dylib)打包进tauri,并在干净电脑上能正常运行,应该如何做?下面是解方法。
比如我们需要把libomp.dylib
打包到tauri应用中,首先我们可以拷贝一份libomp.dylib
库,避免污染原有的库:
bash
cp /usr/local/opt/llvm/lib/libomp.dylib src-tauri/libs/
之后修改tauri.conf.json,需要添加tauri.bundle.macOS.frameworks
的值,示例如下:
json
{
"tauri": {
"bundle": {
"macOS": {
"frameworks": [
"./libs/x86_64/libomp.dylib"
]
}
这样配置的的动态库,在运行程序的时候,会把这些动态库放在src-tauri/target/Frameworks
目录下,在后面运行程序时会使用这个相对位置。
接下来使用otool
命令检查一下这个库的链接位置:
bash
otool -L src-tauri/libs/x86_64/libomp.dylib
打印:
bash
src-tauri/libs/x86_64/libomp.dylib:
/usr/local/opt/llvm/lib/libomp.dylib (compatibility version 5.0.0, current version 5.0.0)
/usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 1311.100.3)
可以发现,虽然libomp.dylib
库的位置在src-tauri/libs/x86_64/
了,但是链接的位置还是/usr/local/opt/llvm/lib/libomp.dylib
。
这时使用yarn tauri build
打包,当打包后的app到一个干净的电脑的时候,会报没有这个库的错误的,此时还需要修改这个动态库的链接位置,使用下面语句:
bash
install_name_tool -id @executable_path/../Frameworks/libomp.dylib src-tauri/libs/x86_64/libomp.dylib
即可把本地链接的动态库路径改为相对执行路径,@executable_path
变量是指可执行文件的路径。
再打印改库的链接信息:
bash
otool -L src-tauri/libs/x86_64/libomp.dylib
输出:
bash
src-tauri/libs/x86_64/libomp.dylib:
@executable_path/../Frameworks/libomp.dylib (compatibility version 5.0.0, current version 5.0.0)
/usr/lib/libSystem.B.dylib (compatibility version 1.0.0, current version 1311.100.3)
可以发现,/usr/local/opt/llvm/lib/libomp.dylib
部分变为了@executable_path/../Frameworks/libomp.dylib
,此时打包后再放到干净电脑就可以正常运行,因为调用了相对位置的动态库,而且生成的dmg包也可以直接安装使用了。
参考资料: