feat: Drop public dependency to Boost.Asio and use standalone asio

This commit is contained in:
Dennis Klein 2021-05-28 15:34:24 +02:00 committed by Dennis Klein
parent 03ba9eb558
commit 9585c20b7f
8 changed files with 55 additions and 70 deletions

View File

@ -121,7 +121,7 @@ if(BUILD_DOCS)
DESTINATION ${PROJECT_INSTALL_DATADIR}/docs DESTINATION ${PROJECT_INSTALL_DATADIR}/docs
) )
endif() endif()
if(BUILD_SDK) if(BUILD_FAIRMQ OR BUILD_SDK)
if(asio_BUNDLED) if(asio_BUNDLED)
install_bundled(asio) install_bundled(asio)
endif() endif()

View File

@ -42,9 +42,6 @@ if(BUILD_FAIRMQ OR BUILD_SDK)
find_package2(PUBLIC Boost REQUIRED VERSION 1.66 find_package2(PUBLIC Boost REQUIRED VERSION 1.66
COMPONENTS container program_options filesystem date_time regex COMPONENTS container program_options filesystem date_time regex
) )
endif()
if(BUILD_SDK)
set(__asio_version 1.18.1) set(__asio_version 1.18.1)
find_package2(BUNDLED asio VERSION ${__asio_version}) find_package2(BUNDLED asio VERSION ${__asio_version})
if(NOT asio_FOUND AND NOT asio_BUNDLED) if(NOT asio_FOUND AND NOT asio_BUNDLED)

View File

@ -49,12 +49,6 @@ if(BUILD_FAIRMQ OR BUILD_SDK)
) )
target_compile_features(${target} PUBLIC cxx_std_17) target_compile_features(${target} PUBLIC cxx_std_17)
target_compile_definitions(${target} PUBLIC BOOST_ERROR_CODE_HEADER_ONLY) target_compile_definitions(${target} PUBLIC BOOST_ERROR_CODE_HEADER_ONLY)
# workaround https://github.com/boostorg/asio/commit/43874d5497414c67655d901e48c939ef01337edb
if( Boost_VERSION VERSION_LESS 1.69
AND CMAKE_CXX_COMPILER_ID STREQUAL AppleClang
AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 10.0.1)
target_compile_definitions(${target} PUBLIC BOOST_ASIO_HAS_STD_STRING_VIEW)
endif()
target_include_directories(${target} target_include_directories(${target}
PUBLIC PUBLIC
$<BUILD_INTERFACE:${CMAKE_SOURCE_DIR}> $<BUILD_INTERFACE:${CMAKE_SOURCE_DIR}>
@ -64,8 +58,9 @@ if(BUILD_FAIRMQ OR BUILD_SDK)
PRIVATE PRIVATE
FairLogger::FairLogger FairLogger::FairLogger
Threads::Threads Threads::Threads
PUBLIC
Boost::boost Boost::boost
PUBLIC
asio::asio
) )
set_target_properties(${target} PROPERTIES set_target_properties(${target} PROPERTIES
VERSION ${PROJECT_VERSION} VERSION ${PROJECT_VERSION}

View File

@ -9,7 +9,7 @@
set(plugin FairMQPlugin_dds) set(plugin FairMQPlugin_dds)
add_library(${plugin} SHARED ${CMAKE_CURRENT_SOURCE_DIR}/DDS.cxx ${CMAKE_CURRENT_SOURCE_DIR}/DDS.h) add_library(${plugin} SHARED ${CMAKE_CURRENT_SOURCE_DIR}/DDS.cxx ${CMAKE_CURRENT_SOURCE_DIR}/DDS.h)
target_compile_features(${plugin} PUBLIC cxx_std_17) target_compile_features(${plugin} PUBLIC cxx_std_17)
target_link_libraries(${plugin} PUBLIC FairMQ StateMachine DDS::dds_intercom_lib DDS::dds_protocol_lib Boost::boost PRIVATE Commands) target_link_libraries(${plugin} PUBLIC FairMQ StateMachine DDS::dds_intercom_lib DDS::dds_protocol_lib Boost::boost PRIVATE Commands asio::asio)
target_include_directories(${plugin} PRIVATE ${CMAKE_CURRENT_BINARY_DIR}) target_include_directories(${plugin} PRIVATE ${CMAKE_CURRENT_BINARY_DIR})
set_target_properties(${plugin} PROPERTIES CXX_VISIBILITY_PRESET hidden) set_target_properties(${plugin} PROPERTIES CXX_VISIBILITY_PRESET hidden)
set_target_properties(${plugin} PROPERTIES set_target_properties(${plugin} PROPERTIES

View File

@ -13,7 +13,7 @@
#include <boost/algorithm/string/join.hpp> #include <boost/algorithm/string/join.hpp>
#include <boost/algorithm/string/split.hpp> #include <boost/algorithm/string/split.hpp>
#include <boost/algorithm/string/classification.hpp> #include <boost/algorithm/string/classification.hpp>
#include <boost/asio/post.hpp> #include <asio/post.hpp>
#include <cstdlib> #include <cstdlib>
#include <stdexcept> #include <stdexcept>
@ -243,7 +243,7 @@ auto DDS::SubscribeForConnectingChannels() -> void
string channelName = key.substr(8); string channelName = key.substr(8);
LOG(info) << "Update for channel name: " << channelName; LOG(info) << "Update for channel name: " << channelName;
boost::asio::post(fWorkerQueue, [=]() { asio::post(fWorkerQueue, [=]() {
try { try {
{ {
unique_lock<mutex> lk(fUpdateMutex); unique_lock<mutex> lk(fUpdateMutex);

View File

@ -18,9 +18,9 @@
#include <dds/dds.h> #include <dds/dds.h>
#undef BOOST_BIND_GLOBAL_PLACEHOLDERS #undef BOOST_BIND_GLOBAL_PLACEHOLDERS
#include <boost/asio/executor.hpp> #include <asio/executor.hpp>
#include <boost/asio/executor_work_guard.hpp> #include <asio/executor_work_guard.hpp>
#include <boost/asio/io_context.hpp> #include <asio/io_context.hpp>
#include <cassert> #include <cassert>
#include <chrono> #include <chrono>
@ -168,8 +168,8 @@ class DDS : public Plugin
std::condition_variable fUpdateCondition; std::condition_variable fUpdateCondition;
std::thread fWorkerThread; std::thread fWorkerThread;
boost::asio::io_context fWorkerQueue; asio::io_context fWorkerQueue;
boost::asio::executor_work_guard<boost::asio::executor> fWorkGuard; asio::executor_work_guard<asio::executor> fWorkGuard;
}; };
Plugin::ProgOptions DDSProgramOptions() Plugin::ProgOptions DDSProgramOptions()

View File

@ -1,5 +1,5 @@
/******************************************************************************** /********************************************************************************
* Copyright (C) 2017 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH * * Copyright (C) 2017-2021 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
* * * *
* This software is distributed under the terms of the * * This software is distributed under the terms of the *
* GNU Lesser General Public Licence (LGPL) version 3, * * GNU Lesser General Public Licence (LGPL) version 3, *
@ -13,28 +13,25 @@
#define _GNU_SOURCE // To get defns of NI_MAXSERV and NI_MAXHOST #define _GNU_SOURCE // To get defns of NI_MAXSERV and NI_MAXHOST
#endif #endif
#include <boost/algorithm/string.hpp> // trim
#include <boost/asio.hpp>
#include <ifaddrs.h>
#include <netdb.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <algorithm> #include <algorithm>
#include <array> #include <array>
#include <boost/algorithm/string.hpp> // trim
#include <boost/asio.hpp>
#include <cstdio> #include <cstdio>
#include <exception> #include <exception>
#include <fstream> #include <fstream>
#include <ifaddrs.h>
#include <iostream> #include <iostream>
#include <map> #include <map>
#include <netdb.h>
#include <stdexcept> #include <stdexcept>
#include <string> #include <string>
#include <sys/socket.h>
#include <sys/types.h>
using namespace std; using namespace std;
namespace fair::mq::tools namespace fair::mq::tools {
{
// returns a map with network interface names as keys and their IP addresses as values // returns a map with network interface names as keys and their IP addresses as values
map<string, string> getHostIPs() map<string, string> getHostIPs()
@ -56,7 +53,13 @@ map<string, string> getHostIPs()
} }
if (ifa->ifa_addr->sa_family == AF_INET) { if (ifa->ifa_addr->sa_family == AF_INET) {
s = getnameinfo(ifa->ifa_addr, sizeof(sockaddr_in), host.data(), NI_MAXHOST, nullptr, 0, NI_NUMERICHOST); s = getnameinfo(ifa->ifa_addr,
sizeof(sockaddr_in),
host.data(),
NI_MAXHOST,
nullptr,
0,
NI_NUMERICHOST);
if (s != 0) { if (s != 0) {
cout << "getnameinfo() failed: " << gai_strerror(s) << endl; cout << "getnameinfo() failed: " << gai_strerror(s) << endl;
throw runtime_error("getnameinfo() failed"); throw runtime_error("getnameinfo() failed");
@ -79,7 +82,8 @@ string getInterfaceIP(const string& interface)
if (IPs.count(interface) > 0) { if (IPs.count(interface) > 0) {
return IPs[interface]; return IPs[interface];
} }
LOG(error) << "Could not find provided network interface: \"" << interface << "\"!, exiting."; LOG(error) << "Could not find provided network interface: \""
<< interface << "\"!, exiting.";
return ""; return "";
} catch (runtime_error& re) { } catch (runtime_error& re) {
cout << "could not get interface IP: " << re.what(); cout << "could not get interface IP: " << re.what();
@ -95,7 +99,8 @@ string getDefaultRouteNetworkInterface()
string interfaceName; string interfaceName;
#ifdef __APPLE__ // MacOS #ifdef __APPLE__ // MacOS
unique_ptr<FILE, decltype(pclose) *> file(popen("route -n get default | grep interface | cut -d \":\" -f 2", "r"), pclose); unique_ptr<FILE, decltype(pclose)*> file(
popen("route -n get default | grep interface | cut -d \":\" -f 2", "r"), pclose);
#else // Linux #else // Linux
ifstream is("/proc/net/route"); ifstream is("/proc/net/route");
string line; string line;
@ -114,14 +119,17 @@ string getDefaultRouteNetworkInterface()
if (line.substr(pos + 1, 8) == "00000000") { if (line.substr(pos + 1, 8) == "00000000") {
interfaceName = line.substr(0, pos); interfaceName = line.substr(0, pos);
LOG(debug) << "Detected network interface name for the default route: " << interfaceName; LOG(debug) << "Detected network interface name for the default route: "
<< interfaceName;
return interfaceName; return interfaceName;
} }
} }
LOG(debug) << "could not get network interface of the default route from /proc/net/route, going to try via 'ip route'"; LOG(debug) << "could not get network interface of the default route from /proc/net/route, "
"going to try via 'ip route'";
unique_ptr<FILE, decltype(pclose) *> file(popen("ip route | grep default | cut -d \" \" -f 5 | head -n 1", "r"), pclose); unique_ptr<FILE, decltype(pclose)*> file(
popen("ip route | grep default | cut -d \" \" -f 5 | head -n 1", "r"), pclose);
#endif #endif
if (!file) { if (!file) {
@ -138,8 +146,10 @@ string getDefaultRouteNetworkInterface()
boost::algorithm::trim(interfaceName); boost::algorithm::trim(interfaceName);
if (interfaceName.empty()) { if (interfaceName.empty()) {
LOG(debug) << "Could not detect default route network interface name from /proc/net/route nor 'ip route'"; LOG(debug) << "Could not detect default route network interface name from /proc/net/route "
throw DefaultRouteDetectionError("Could not detect default route network interface name from /proc/net/route nor 'ip route'"); "nor 'ip route'";
throw DefaultRouteDetectionError("Could not detect default route network interface name "
"from /proc/net/route nor 'ip route'");
} else { } else {
LOG(debug) << "Detected network interface name for the default route: " << interfaceName; LOG(debug) << "Detected network interface name for the default route: " << interfaceName;
} }
@ -149,25 +159,22 @@ string getDefaultRouteNetworkInterface()
string getIpFromHostname(const string& hostname) string getIpFromHostname(const string& hostname)
{ {
boost::asio::io_service ios; boost::asio::io_context ioc;
return getIpFromHostname(hostname, ios);
} using namespace boost::asio::ip;
string getIpFromHostname(const string& hostname, boost::asio::io_service& ios)
{
try { try {
namespace bai = boost::asio::ip; tcp::resolver resolver(ioc);
bai::tcp::resolver resolver(ios); tcp::resolver::query query(hostname, "");
bai::tcp::resolver::query query(hostname, ""); tcp::resolver::iterator end;
bai::tcp::resolver::iterator end;
auto it = find_if(static_cast<bai::basic_resolver_iterator<bai::tcp>>(resolver.resolve(query)), end, [](const bai::tcp::endpoint& ep) { auto it = find_if(static_cast<basic_resolver_iterator<tcp>>(resolver.resolve(query)),
return ep.address().is_v4(); end,
}); [](const tcp::endpoint& ep) { return ep.address().is_v4(); });
if (it != end) { if (it != end) {
stringstream ss; stringstream ss;
ss << static_cast<bai::tcp::endpoint>(*it).address(); ss << static_cast<tcp::endpoint>(*it).address();
return ss.str(); return ss.str();
} }

View File

@ -1,5 +1,5 @@
/******************************************************************************** /********************************************************************************
* Copyright (C) 2017 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH * * Copyright (C) 2017-2021 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
* * * *
* This software is distributed under the terms of the * * This software is distributed under the terms of the *
* GNU Lesser General Public Licence (LGPL) version 3, * * GNU Lesser General Public Licence (LGPL) version 3, *
@ -13,18 +13,6 @@
#include <string> #include <string>
#include <stdexcept> #include <stdexcept>
// forward declarations
namespace boost
{
namespace asio
{
class io_context;
using io_service = class io_context;
} // namespace asio
} // namespace boost
namespace fair::mq::tools namespace fair::mq::tools
{ {
@ -41,8 +29,6 @@ std::string getDefaultRouteNetworkInterface();
std::string getIpFromHostname(const std::string& hostname); std::string getIpFromHostname(const std::string& hostname);
std::string getIpFromHostname(const std::string& hostname, boost::asio::io_service& ios);
} // namespace fair::mq::tools } // namespace fair::mq::tools
#endif /* FAIR_MQ_TOOLS_NETWORK_H */ #endif /* FAIR_MQ_TOOLS_NETWORK_H */