首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Bazel构建Boost日志示例时遇到的问题

使用Bazel构建Boost日志示例时遇到的问题
EN

Stack Overflow用户
提问于 2021-12-21 21:52:22
回答 1查看 164关注 0票数 0

我正在使用Bazel作为我的构建系统,在我开始尝试使用Boost日志之前,没有出现过Boost up的问题,我甚至能够使用一些编译好的库,而不存在任何问题。但是,当尝试使用Boost.Log或试图为普通日志构建示例时,我会得到许多未定义的引用错误。

我尝试使用以下bazel构建命令进行构建:

bazel build //app:boost-log-test

bazel build --cxxopt="-pthread" //app:boost-log-test

bazel build --cxxopt="-lpthread" //app:boost-log-test

bazel build --cxxopt="-DBOOST_LOG_DYN_LINK" --cxxopt="-lpthread" //app:boost-log-test

bazel build --cxxopt="-lboost_log" --cxxopt="-lpthread" //app:boost-log-test

bazel build --cxxopt="-DBOOST_LOG_DYN_LINK" --cxxopt="-lboost_log" //app:boost-log-test

bazel build --cxxopt="-DBOOST_LOG_DYN_LINK" --cxxopt="-lboost_log" --cxxopt="-lpthread" //app:boost-log-test

bazel build --cxxopt="-DBOOST_LOG_DYN_LINK" --cxxopt="-lboost_log" --cxxopt="-lpthread" --cxxopt="-std=c++17" //app:boost-log-test

所有这些都导致了同样的错误,这是我在这篇文章的末尾所包含的。我的Boost根目录位于/opt/boost/boost_1_77_0,下面是我的项目结构。

./WORKSPACE

代码语言:javascript
复制
new_local_repository(
    name = "boost",
    path = "/opt/boost/boost_1_77_0",
    build_file = "external/boost.BUILD",
)

./external/boost.BUILD

代码语言:javascript
复制
load("@rules_cc//cc:defs.bzl", "cc_library")

cc_library(
    name = "boost-headers",
    hdrs = glob(["include/boost/**"]),
    visibility = ["//visibility:public"],
    includes = ['include'],
)

cc_library(
    name = "boost-allbuilt",
    srcs = glob(["lib/*.a"]),
    visibility = ["//visibility:public"],
)

...

cc_library(
    name = "boost-log",
    srcs = ["lib/libboost_log.a"],
    visibility = ["//visibility:public"],
)

cc_library(
    name = "boost-log_setup",
    srcs = ["lib/libboost_log_setup.a"],
    visibility = ["//visibility:public"],
)

...

cc_library(
    name = "boost-wserialization",
    srcs = ["lib/libboost_wserialization.a"],
    visibility = ["//visibility:public"],
)

./app/BUILD

代码语言:javascript
复制
load("@rules_cc//cc:defs.bzl", "cc_binary")

cc_binary(
    name = "boost-log-test",
    srcs = ["log_test.cpp"],
    deps = [
        "@boost//:boost-headers",
        "@boost//:boost-log_setup",
        "@boost//:boost-log",
    ],
)

./app/log_test.cpp (/opt/boost/boost_1_77_0/libs/log/example/trivial/main.cpp的确切副本):

代码语言:javascript
复制
/*
 *          Copyright Andrey Semashev 2007 - 2015.
 * Distributed under the Boost Software License, Version 1.0.
 *    (See accompanying file LICENSE_1_0.txt or copy at
 *          http://www.boost.org/LICENSE_1_0.txt)
 */
/*!
 * \file   main.cpp
 * \author Andrey Semashev
 * \date   07.11.2009
 *
 * \brief  An example of trivial logging.
 */

// #define BOOST_ALL_DYN_LINK 1
// #define BOOST_LOG_DYN_LINK 1

#include <boost/log/trivial.hpp>
#include <boost/log/core.hpp>
#include <boost/log/expressions.hpp>

int main(int argc, char* argv[])
{
    // Trivial logging: all log records are written into a file
    BOOST_LOG_TRIVIAL(trace) << "A trace severity message";
    BOOST_LOG_TRIVIAL(debug) << "A debug severity message";
    BOOST_LOG_TRIVIAL(info) << "An informational severity message";
    BOOST_LOG_TRIVIAL(warning) << "A warning severity message";
    BOOST_LOG_TRIVIAL(error) << "An error severity message";
    BOOST_LOG_TRIVIAL(fatal) << "A fatal severity message";

    // Filtering can also be applied
    using namespace boost::log;

    core::get()->set_filter
    (
        trivial::severity >= trivial::info
    );

    // Now the first two lines will not pass the filter
    BOOST_LOG_TRIVIAL(trace) << "A trace severity message";
    BOOST_LOG_TRIVIAL(debug) << "A debug severity message";
    BOOST_LOG_TRIVIAL(info) << "An informational severity message";
    BOOST_LOG_TRIVIAL(warning) << "A warning severity message";
    BOOST_LOG_TRIVIAL(error) << "An error severity message";
    BOOST_LOG_TRIVIAL(fatal) << "A fatal severity message";

    return 0;
}

生成输出:

代码语言:javascript
复制
[user@computer cpp]$ bazel build --cxxopt="-DBOOST_LOG_DYN_LINK" --cxxopt="-lboost_log" --cxxopt="-lpthread" --cxxopt="-std=c++17" //app:boost-log-test
INFO: Analyzed target //app:boost-log-test (0 packages loaded, 0 targets configured).
INFO: Found 1 target...
ERROR: /home/blueder/Projects/MarketProphet/cpp/app/BUILD:11:10: Linking app/boost-log-test failed: (Exit 1): gcc failed: error executing command /usr/bin/gcc @bazel-out/k8-fastbuild/bin/app/boost-log-test-2.params

Use --sandbox_debug to see verbose messages from the sandbox
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function main: error: undefined reference to 'boost::log::v2_mt_posix::trivial::logger::get()'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function main: error: undefined reference to 'boost::log::v2_mt_posix::trivial::logger::get()'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function main: error: undefined reference to 'boost::log::v2_mt_posix::trivial::logger::get()'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function main: error: undefined reference to 'boost::log::v2_mt_posix::trivial::logger::get()'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function main: error: undefined reference to 'boost::log::v2_mt_posix::core::get()'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function main: error: undefined reference to 'boost::log::v2_mt_posix::core::set_filter(boost::log::v2_mt_posix::filter const&)'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::aux::light_rw_mutex::lock_shared(): error: undefined reference to 'pthread_rwlock_rdlock'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::aux::light_rw_mutex::unlock_shared(): error: undefined reference to 'pthread_rwlock_unlock'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::attribute_name::attribute_name(char const*): error: undefined reference to 'boost::log::v2_mt_posix::attribute_name::get_id_from_string(char const*)'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::record::reset(): error: undefined reference to 'boost::log::v2_mt_posix::record_view::public_data::destroy(boost::log::v2_mt_posix::record_view::public_data const*)'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::record boost::log::v2_mt_posix::sources::basic_composite_logger<char, boost::log::v2_mt_posix::sources::severity_logger_mt<boost::log::v2_mt_posix::trivial::severity_level>, boost::log::v2_mt_posix::sources::multi_thread_model<boost::log::v2_mt_posix::aux::light_rw_mutex>, boost::log::v2_mt_posix::sources::features<boost::log::v2_mt_posix::sources::severity<boost::log::v2_mt_posix::trivial::severity_level> > >::open_record<boost::parameter::aux::tagged_argument_list_of_1<boost::parameter::aux::tagged_argument<boost::log::v2_mt_posix::keywords::tag::severity, boost::log::v2_mt_posix::trivial::severity_level const> > >(boost::parameter::aux::tagged_argument_list_of_1<boost::parameter::aux::tagged_argument<boost::log::v2_mt_posix::keywords::tag::severity, boost::log::v2_mt_posix::trivial::severity_level const> > const&): error: undefined reference to 'boost::log::v2_mt_posix::core::get_logging_enabled() const'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::aux::record_pump<boost::log::v2_mt_posix::sources::severity_logger_mt<boost::log::v2_mt_posix::trivial::severity_level> >::record_pump(boost::log::v2_mt_posix::sources::severity_logger_mt<boost::log::v2_mt_posix::trivial::severity_level>&, boost::log::v2_mt_posix::record&): error: undefined reference to 'boost::log::v2_mt_posix::aux::stream_provider<char>::allocate_compound(boost::log::v2_mt_posix::record&)'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::aux::record_pump<boost::log::v2_mt_posix::sources::severity_logger_mt<boost::log::v2_mt_posix::trivial::severity_level> >::auto_release::~auto_release(): error: undefined reference to 'boost::log::v2_mt_posix::aux::stream_provider<char>::release_compound(boost::log::v2_mt_posix::aux::stream_provider<char>::stream_compound*)'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::sources::aux::severity_level<boost::log::v2_mt_posix::trivial::severity_level>::set_value(boost::log::v2_mt_posix::trivial::severity_level): error: undefined reference to 'boost::log::v2_mt_posix::sources::aux::get_severity_level()'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::record boost::log::v2_mt_posix::sources::basic_logger<char, boost::log::v2_mt_posix::sources::severity_logger_mt<boost::log::v2_mt_posix::trivial::severity_level>, boost::log::v2_mt_posix::sources::multi_thread_model<boost::log::v2_mt_posix::aux::light_rw_mutex> >::open_record_unlocked<boost::parameter::aux::tagged_argument_list_of_1<boost::parameter::aux::tagged_argument<boost::log::v2_mt_posix::keywords::tag::severity, boost::log::v2_mt_posix::trivial::severity_level const> > >(boost::parameter::aux::tagged_argument_list_of_1<boost::parameter::aux::tagged_argument<boost::log::v2_mt_posix::keywords::tag::severity, boost::log::v2_mt_posix::trivial::severity_level const> > const&): error: undefined reference to 'boost::log::v2_mt_posix::core::open_record(boost::log::v2_mt_posix::attribute_set const&)'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::sources::basic_logger<char, boost::log::v2_mt_posix::sources::severity_logger_mt<boost::log::v2_mt_posix::trivial::severity_level>, boost::log::v2_mt_posix::sources::multi_thread_model<boost::log::v2_mt_posix::aux::light_rw_mutex> >::push_record_unlocked(boost::log::v2_mt_posix::record&&): error: undefined reference to 'boost::log::v2_mt_posix::core::push_record_move(boost::log::v2_mt_posix::record&)'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::value_extractor<boost::log::v2_mt_posix::trivial::severity_level, boost::log::v2_mt_posix::fallback_to_none, boost::log::v2_mt_posix::trivial::tag::severity>::operator()(boost::log::v2_mt_posix::attribute_name const&, boost::log::v2_mt_posix::attribute_value_set const&) const: error: undefined reference to 'boost::log::v2_mt_posix::attribute_value_set::find(boost::log::v2_mt_posix::attribute_name) const'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::value_extractor<boost::log::v2_mt_posix::trivial::severity_level, boost::log::v2_mt_posix::fallback_to_none, boost::log::v2_mt_posix::trivial::tag::severity>::operator()(boost::log::v2_mt_posix::attribute_name const&, boost::log::v2_mt_posix::attribute_value_set const&) const: error: undefined reference to 'boost::log::v2_mt_posix::attribute_value_set::end() const'
bazel-out/k8-fastbuild/bin/app/_objs/boost-log-test/log_test.pic.o:log_test.cpp:function boost::log::v2_mt_posix::value_extractor<boost::log::v2_mt_posix::trivial::severity_level, boost::log::v2_mt_posix::fallback_to_none, boost::log::v2_mt_posix::trivial::tag::severity>::operator()(boost::log::v2_mt_posix::attribute_name const&, boost::log::v2_mt_posix::attribute_value_set const&) const: error: undefined reference to 'boost::log::v2_mt_posix::aux::attach_attribute_name_info(boost::exception&, boost::log::v2_mt_posix::attribute_name const&)'
collect2: error: ld returned 1 exit status
Target //app:boost-log-test failed to build
Use --verbose_failures to see the command lines of failed build steps.
INFO: Elapsed time: 0.175s, Critical Path: 0.04s
INFO: 2 processes: 2 internal.
FAILED: Build did NOT complete successfully
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-21 23:32:39

  1. --cxxopt选项传递给编译步骤,而不是链接步骤,因此任何形式的--cxxopt=-lsomelib。使用--linkopts在命令行上配置链接标志,或者将linkopts = ['-pthread']添加到cc目标。
  2. 您可能希望节省一些精力,并使用提升Bazel规则的pre x
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70441996

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档