发布使用 IMGui 基于 msys2 平台编写的软件
最近空闲时间为项目编写一个协议测试工具。由于习惯使用 gcc/g++ 所以在 Windows 10 操作系统上选择 msys2 开发。编程语言是 C/C++ 和 Lua ,界面基于 imgui ,使用云风大大编写的 lua binding 。总体体验很好。下面是发布过程中碰见的一些问题。
缺失 DLL 问题。在 Windows Explorer 中双击运行 exe 文件,提示缺失一系列的 DLL 文件,这时把相关的 DLL 文件拷贝到 exe 文件所在目录即可。除了 exe 本身依赖的 DLL ,还有一些 msys2 依赖的 DLL ,比如 libgcc_s_seh-1.dll 和 libwinpthread-1.dll 。
exe 文件无法启动,弹出应用程序无法正常启动( 0xc000007b )。请单击确定关闭应用程序 问题。我参考了这篇博客,上面提到了 msvcr120.dll 是 32 位需要被换成 64 位,来启动 64 位应用程序。此外,又在这篇看见了如下回答:
You may like to add the options -static-libgcc and -static-libstdc++ to link the C and C++ standard libraries statically and thus remove the need to carry around any separate copies of those.
灵机一动,在 g++ 编译时加上了 -static-libstdc++ 选项,重新编译然后应用程序正常启动。
起初出现这个无法正常启动问题,我还以为是 msys2 平台用 g++ 生成的 exe 文件无法通过 Windows Explorer 启动,现在看来,是我猜错了。然而为什么使用 -static-libstdc++ 静态 C++ 标准库就可以正常启动,暂时还不知原因。
Lua 无法加载 C 库问题。exe 文件成功启动后,产生如下报错:
fail to init:error loading module 'crypto' from file './scripts/luaclib/crypto.dll':
找不到指定的模块。
crypto.dll 是用 C 编写的加密库,依赖 openssl 。于是用 ldd crypto.dll 查看依赖的动态库,发现依赖 libeay32.dll ,而此文件正属于 openssl 。把 libeay32.dll 拷贝到 exe 文件所在目录,再次加载 C 库即可成功。
其实 Lua 无法加载 C 库,如果能给出更明确的出错信息,而不简单的是找不到指定模块就最好不过了。
上面就是首次使用 msys2 编写软件发布时碰见的问题,上面的问题知道了怎么解决,但是细节还不太清楚,有时间可以深究一下。