简体   繁体   English

Boost日志链接错误(Cmake Mingw32)

[英]Boost log linking errors (Cmake Mingw32)

I have this cmake file: 我有这个cmake文件:

cmake_minimum_required(VERSION 3.6)

find_package(Boost 1.54.0 REQUIRED COMPONENTS log)

add_executable(TestProject main.cpp)

target_include_directories(TestProject PUBLIC ${Boost_INCLUDE_DIRS})
target_link_libraries(TestProject Boost::log)
add_definitions("-DBOOST_ALL_NO_LIB") # Disable boost auto-linking.
add_definitions("-DBOOST_LOG_DYN_LINK") # Avoid linking errors with boost::log

If I build it using Visual Studio as my generator from a Visual-Studio developer console, I can build just fine. 如果我使用Visual Studio作为Visual Studio开发人员控制台的生成器来构建它,则可以很好地进行构建。 However in my MinGW32 environment I get linker errors. 但是,在我的MinGW32环境中,出现链接器错误。 I can confirm that boost is installed in my mingw32 environment and is working well for other projects (which use other boost components). 我可以确认boost已安装在mingw32环境中,并且对于其他项目(使用其他boost组件)也能正常工作。

stewart@PC-1234 MINGW32 ~/src/testproj/buildmsys
$ tree /mingw32 -f | grep libboost_log
│   ├── /mingw32/bin/libboost_log_setup-mt.dll
│   ├── /mingw32/bin/libboost_log-mt.dll
│   ├── /mingw32/lib/libboost_log_setup-mt.a
│   ├── /mingw32/lib/libboost_log_setup-mt.dll.a
│   ├── /mingw32/lib/libboost_log-mt.a
│   ├── /mingw32/lib/libboost_log-mt.dll.a

I build with: 我用:

$ mkdir buildmsys && cd buildmsys
$ cmake .. -GNinja
$ cmake --build .

And here is the output 这是输出

stewart@PC-1234 MINGW32 ~/src/TestProject/buildmsys
$ cmake .. -GNinja
-- Boost version: 1.63.0
-- Found the following Boost libraries:
--   log
--   date_time
--   log_setup
--   system
--   filesystem
--   thread
--   regex
--   chrono
--   atomic
-- Configuring done
-- Generating done
-- Build files have been written to: 
C:/msys64/home/stewart/src/TestProject/buildmsys

stewart@PC-1234 MINGW32 ~/src/TestProject/buildmsys
$ cmake --build .
[1/1] Linking CXX executable TestProject.exe
FAILED: TestProject.exe
cmd.exe /C "cd . && C:\msys64\mingw32\bin\c++.exe CMakeFiles/TestProject.dir/main.cpp.obj  -o TestProject.exe -Wl,--major-image-version,0,--minor-image-version,0 C:/msys64/mingw32/lib/libboost_log-mt.dll.a C:/msys64/mingw32/lib/libboost_log_setup-mt.dll.a C:/msys64/mingw32/lib/libboost_filesystem-mt.dll.a C:/msys64/mingw32/lib/libboost_thread-mt.dll.a C:/msys64/mingw32/lib/libboost_date_time-mt.dll.a C:/msys64/mingw32/lib/libboost_regex-mt.dll.a C:/msys64/mingw32/lib/libboost_chrono-mt.dll.a C:/msys64/mingw32/lib/libboost_system-mt.dll.a C:/msys64/mingw32/lib/libboost_atomic-mt.dll.a -lkernel32 -luser32 -lgdi32 -lwinspool -lshell32 -lole32 -loleaut32 -luuid -lcomdlg32 -ladvapi32 && cd ."
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text+0x151): undefined reference to `_imp___ZN5boost3log9v2_mt_nt64core3getEv'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text+0x2b5): undefined reference to `_imp___ZN5boost3log9v2_mt_nt64core10set_filterERKNS1_6filterE'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text+0x35a): undefined reference to `_imp___ZN5boost3log9v2_mt_nt64core3getEv'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text+0x4e2): undefined reference to `_imp___ZN5boost3log9v2_mt_nt64core10set_filterERKNS1_6filterE'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text+0x53c): undefined reference to `_imp___ZN5boost3log9v2_mt_nt67trivial6logger3getEv'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text+0x5a2): undefined reference to `_imp___ZN5boost3log9v2_mt_nt67trivial6logger3getEv'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text$_ZN5boost3log9v2_mt_nt614attribute_nameC1EPKc[__ZN5boost3log9v2_mt_nt614attribute_nameC1EPKc]+0x10): undefined reference to `_imp___ZN5boost3log9v2_mt_nt614attribute_name18get_id_from_stringEPKc'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text$_ZNK5boost3log9v2_mt_nt615value_extractorINS1_7trivial14severity_levelENS1_16fallback_to_noneENS3_3tag8severityEEclERKNS1_14attribute_nameERKNS1_19attribute_value_setE[__ZNK5boost3log9v2_mt_nt615value_extractorINS1_7trivial14severity_levelENS1_16fallback_to_noneENS3_3tag8severityEEclERKNS1_14attribute_nameERKNS1_19attribute_value_setE]+0x19): undefined reference to `_imp___ZNK5boost3log9v2_mt_nt619attribute_value_set4findENS1_14attribute_nameE'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text$_ZNK5boost3log9v2_mt_nt615value_extractorINS1_7trivial14severity_levelENS1_16fallback_to_noneENS3_3tag8severityEEclERKNS1_14attribute_nameERKNS1_19attribute_value_setE[__ZNK5boost3log9v2_mt_nt615value_extractorINS1_7trivial14severity_levelENS1_16fallback_to_noneENS3_3tag8severityEEclERKNS1_14attribute_nameERKNS1_19attribute_value_setE]+0x2e): undefined reference to `_imp___ZNK5boost3log9v2_mt_nt619attribute_value_set3endEv'
CMakeFiles/TestProject.dir/main.cpp.obj:main.cpp:(.text$_ZNK5boost3log9v2_mt_nt615value_extractorINS1_7trivial14severity_levelENS1_16fallback_to_noneENS3_3tag8severityEEclERKNS1_14attribute_nameERKNS1_19attribute_value_setE[__ZNK5boost3log9v2_mt_nt615value_extractorINS1_7trivial14severity_levelENS1_16fallback_to_noneENS3_3tag8severityEEclERKNS1_14attribute_nameERKNS1_19attribute_value_setE]+0xe0): undefined reference to `_imp___ZN5boost3log9v2_mt_nt63aux26attach_attribute_name_infoERNS_9exceptionERKNS1_14attribute_nameE'
collect2.exe: error: ld returned 1 exit status
ninja: build stopped: subcommand failed.

What's wrong with my setup? 我的设置有什么问题?

Note: I've already checked (and tried) these links in case my question was a duplicate: 注意:我已经检查(并尝试过)这些链接,以防我的问题重复:

If I look at those solutions, the unicode one is the only one I haven't gotten to work. 如果我看这些解决方案,那么unicode就是我唯一没有使用过的解决方案。 I've added add_definitions("-Zc:wchar_t") to my Cmake file, but I get an unrecognized command line option error from c++.exe (since that flag is VS-specific). 我已经将add_definitions("-Zc:wchar_t")到我的Cmake文件中,但是我从c ++。exe收到了无法识别的命令行选项错误(因为该标志是VS特定的)。

The problem is likely caused by mismatch of the target Windows version between your code and Boost.Log. 该问题很可能是由于代码和Boost.Log之间的目标Windows版本不匹配引起的。 See this answer: 看到这个答案:

Problems Linking boost log 1_60 with MinGw on Windows 7 在Windows 7上将Boost Log 1_60与MinGw链接时出现问题

Most likely, your project defines _WIN32_WINNT somewhere to a value of 0x0600 or higher. 您的项目很可能在某处将_WIN32_WINNT定义为0x0600或更高的值。

Boost defaults to Windows XP when compiled by MinGW because Windows SDK provided by MinGW is too incomplete. 由MinGW编译时,Boost默认为Windows XP,因为MinGW提供的Windows SDK太不完整。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM