electronApp在macOS10.15.7系统上启动报错如上,是加载libLiveTranslate.dylib库失败了。
在/System/Library/Frameworks/VideoToolbox.framework/Versions/A/VideoToolbox里找不到符号:_VTRegisterSuppIementalVideoDecoderlfAvailable。
1)首先查看libLiveTranslate.dylib库依赖了哪些库?
otool -L -X -v libLiveTranslate.dylib
可以看到确实依赖了 /System/Library/Frameworks/VideoToolbox.framework/Versions/A/VideoToolbox库,这个是系统自带的。
2)查看libLiveTranslate.dylib库对_VTRegisterSuppIementalVideoDecoderlfAvailable的引用
nm -m libLiveTranslate.dylib| grep VTRegister
上面显示是从VideoToolbox链接进来的。
3) libLiveTranslate.dylib库因为静态链接了ffmpeg库,所以间接需要链接VideoToolbox库,所以在ffmpeg源码里搜索_VTRegisterSuppIementalVideoDecoderlfAvailable使用的地方
首先if (__builtin_available(macOS 11.0, *))是编译时判断sdk是否是11.0以上,我的sdk是macOS 13.1。通过下面查看
xcodebuild -showsdks
所以,下面这段代码如果为true就会去调用VTRegisterSupplementalVideoDecoderIfAvailable。
#if defined(MAC_OS_VERSION_11_0) && !TARGET_OS_IPHONE && (MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_VERSION_11_0) && AV_HAS_BUILTIN(__builtin_available)
上面这几个宏是定义在下面头文件,
#include <AvailabilityMacros.h>
这几个宏的值应该是由编译时指定的最小macOS版本决定的,具体内部逻辑没细查。
4)查看libLiveTranslate.dylib库链接的ffmpeg静态库支持的最小系统版本
otool -l libavcodec.a| grep -E "(minos|sdk)"
现在需要编译ffmpeg,让它支持最低macOS10.15。
5)macOS下编译支持最低macOS10.15版本的ffmpeg静态库,参考的GitHub - ColorsWind/FFmpeg-macOS: FFmpeg shared universal binaries (x86_64 and arm64) for macOS.
make_compile.py修改如下:
make_universal.py修改如下:
执行完make_universal.py后,在ffmpeg/install_universal/lib目录下 找到了需要的lib,再执行上面的命令,可以看到minos变成10.15.
6)编译支持最低macOS10.15版本的liblmp3lame静态库,这个是mp3的编解码器。
参考的 MacOS 编译 x86_64/arm64 lame - 知乎
对build-lame.sh做了如下修改
编译完后在lame-osx-build/fat-lame/lib 找到需要的libmp3lame.a
7)编译支持最低macOS10.15版本的openssl静态库
参考Mac下openssl的编译和使用_mac openssl-CSDN博客
重新编译libLiveTranslate.dylib库,最后验证这个问题解决了。
8)查看符号表,第一个带weak的是正确的