使用带有 CMake 和 Conan 的外部库的未定义引用

Undefined reference using external library with CMake and Conan

我正在尝试使用 Conan 和 CMake 以及 LibLogicalAccess 库开发一个与 PCSC USB reader 通信的程序。我按照构建和安装库的说明进行操作,看起来一切顺利。我创建了一个带有 "main.cpp" 文件的小型简单控制台项目。在图书馆 wiki 上的 C++ guide 之后,我试图从图书馆调用一个函数,这导致了“对 函数 的未定义引用”。我知道有很多主题涵盖了这一点,但我已经阅读了尽可能多的内容,但似乎找不到正确的解决方案。

我对 Ubuntu/CMake/Conan/C++ 没有太多经验,所以它也可能是一个非常简单的修复。

OS:Kubuntu 18.04 语言:C++ 相关软件:LibLogicalAccess 2.2.1, CMake 3.17.1, 柯南 1.25.0

main.cpp

#include <iostream>

#include <logicalaccess/dynlibrary/librarymanager.hpp>
#include <logicalaccess/readerproviders/readerconfiguration.hpp>
#include <logicalaccess/cards/chip.hpp>

int main()
{
    std::cout << "Program started\n";

    // Reader configuration object to store reader provider and reader unit selection.
    std::shared_ptr<logicalaccess::ReaderConfiguration> readerConfig(new logicalaccess::ReaderConfiguration());

    // Set PCSC ReaderProvider by calling the Library Manager which will load the function from the corresponding plug-in
    readerConfig->setReaderProvider(logicalaccess::LibraryManager::getInstance()->getReaderProvider("PCSC"));

    std::cout << "after..\n";
}

CMakeLists.txt

cmake_minimum_required(VERSION 3.16)

project(project)
include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
conan_basic_setup(TARGETS)
set(CMAKE_CXX_FLAGS "-I /usr/include/PCSC")
add_executable(project main.cpp)
target_link_libraries(project PUBLIC CONAN_PKG::LogicalAccess)

当我尝试使用 cmake --build . 构建程序时,这是输出:

[100%] Linking CXX executable bin/project
CMakeFiles/project.dir/main.cpp.o: In function `main':
main.cpp:(.text+0x140): undefined reference to `logicalaccess::LibraryManager::getReaderProvider(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)'
collect2: error: ld returned 1 exit status
CMakeFiles/project.dir/build.make:191: recipe for target 'bin/project' failed
make[2]: *** [bin/project] Error 1
CMakeFiles/Makefile2:95: recipe for target 'CMakeFiles/project.dir/all' failed
make[1]: *** [CMakeFiles/project.dir/all] Error 2
Makefile:103: recipe for target 'all' failed
make: *** [all] Error 2

奇怪的是,第一行代码:std::shared_ptr<logicalaccess::ReaderConfiguration> readerConfig(...) 工作正常,第二行代码给出了未定义的引用。

我在同一个文件中尝试了其他函数,结果相同。当我删除最后 "setReaderProvider" 行代码时,该文件编译并运行良好。还尝试了很多关于 conanfile.txt 和 CMakeLists.txt 的不同小调整。

您的错误显示:

main.cpp:(.text+0x140): undefined reference to `logicalaccess::LibraryManager::getReaderProvider(std::__cxx11::basic_string, std::allocator > const&)'

这是因为您的 CMake 使用 libstdc++11 到 link,但是,由于向后兼容性,Conan 配置为使用 libstdc++。 您需要更新您的默认 libcxx:

conan profile update settings.compiler.libcxx=libstdc++11 default

请阅读 Conan 文档中的这一部分 How to Manage GCC ABI 以获取更多信息。

此外,在 Getting Started 的第 5 步中进行了解释。

现在再次构建时,您将需要您的本地包不可用,因为它是一个新包,使用不同的设置,因此您需要安装或从源构建。 link 到 libstdc++11 由 Conan 自动管理,它将定义传递给 CMake。

此致!