Skip to content

Commit

Permalink
feat: Drop public dependency to Boost.Asio and use standalone asio
Browse files Browse the repository at this point in the history
  • Loading branch information
dennisklein committed Jul 16, 2021
1 parent 03ba9eb commit 9585c20
Show file tree
Hide file tree
Showing 8 changed files with 55 additions and 70 deletions.
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ if(BUILD_DOCS)
DESTINATION ${PROJECT_INSTALL_DATADIR}/docs
)
endif()
if(BUILD_SDK)
if(BUILD_FAIRMQ OR BUILD_SDK)
if(asio_BUNDLED)
install_bundled(asio)
endif()
Expand Down
3 changes: 0 additions & 3 deletions cmake/FairMQDependencies.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -42,9 +42,6 @@ if(BUILD_FAIRMQ OR BUILD_SDK)
find_package2(PUBLIC Boost REQUIRED VERSION 1.66
COMPONENTS container program_options filesystem date_time regex
)
endif()

if(BUILD_SDK)
set(__asio_version 1.18.1)
find_package2(BUNDLED asio VERSION ${__asio_version})
if(NOT asio_FOUND AND NOT asio_BUNDLED)
Expand Down
9 changes: 2 additions & 7 deletions fairmq/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -49,12 +49,6 @@ if(BUILD_FAIRMQ OR BUILD_SDK)
)
target_compile_features(${target} PUBLIC cxx_std_17)
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}
PUBLIC
$<BUILD_INTERFACE:${CMAKE_SOURCE_DIR}>
Expand All @@ -64,8 +58,9 @@ if(BUILD_FAIRMQ OR BUILD_SDK)
PRIVATE
FairLogger::FairLogger
Threads::Threads
PUBLIC
Boost::boost
PUBLIC
asio::asio
)
set_target_properties(${target} PROPERTIES
VERSION ${PROJECT_VERSION}
Expand Down
2 changes: 1 addition & 1 deletion fairmq/plugins/DDS/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
set(plugin FairMQPlugin_dds)
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_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})
set_target_properties(${plugin} PROPERTIES CXX_VISIBILITY_PRESET hidden)
set_target_properties(${plugin} PROPERTIES
Expand Down
4 changes: 2 additions & 2 deletions fairmq/plugins/DDS/DDS.cxx
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
#include <boost/algorithm/string/join.hpp>
#include <boost/algorithm/string/split.hpp>
#include <boost/algorithm/string/classification.hpp>
#include <boost/asio/post.hpp>
#include <asio/post.hpp>

#include <cstdlib>
#include <stdexcept>
Expand Down Expand Up @@ -243,7 +243,7 @@ auto DDS::SubscribeForConnectingChannels() -> void
string channelName = key.substr(8);
LOG(info) << "Update for channel name: " << channelName;

boost::asio::post(fWorkerQueue, [=]() {
asio::post(fWorkerQueue, [=]() {
try {
{
unique_lock<mutex> lk(fUpdateMutex);
Expand Down
10 changes: 5 additions & 5 deletions fairmq/plugins/DDS/DDS.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,9 @@
#include <dds/dds.h>
#undef BOOST_BIND_GLOBAL_PLACEHOLDERS

#include <boost/asio/executor.hpp>
#include <boost/asio/executor_work_guard.hpp>
#include <boost/asio/io_context.hpp>
#include <asio/executor.hpp>
#include <asio/executor_work_guard.hpp>
#include <asio/io_context.hpp>

#include <cassert>
#include <chrono>
Expand Down Expand Up @@ -168,8 +168,8 @@ class DDS : public Plugin
std::condition_variable fUpdateCondition;

std::thread fWorkerThread;
boost::asio::io_context fWorkerQueue;
boost::asio::executor_work_guard<boost::asio::executor> fWorkGuard;
asio::io_context fWorkerQueue;
asio::executor_work_guard<asio::executor> fWorkGuard;
};

Plugin::ProgOptions DDSProgramOptions()
Expand Down
79 changes: 43 additions & 36 deletions fairmq/tools/Network.cxx
Original file line number Diff line number Diff line change
@@ -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 *
* GNU Lesser General Public Licence (LGPL) version 3, *
Expand All @@ -10,31 +10,28 @@
#include <fairmq/tools/Network.h>

#ifndef _GNU_SOURCE
#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

#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 <array>
#include <boost/algorithm/string.hpp> // trim
#include <boost/asio.hpp>
#include <cstdio>
#include <exception>
#include <fstream>
#include <ifaddrs.h>
#include <iostream>
#include <map>
#include <netdb.h>
#include <stdexcept>
#include <string>
#include <sys/socket.h>
#include <sys/types.h>

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
map<string, string> getHostIPs()
Expand All @@ -56,7 +53,13 @@ map<string, string> getHostIPs()
}

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) {
cout << "getnameinfo() failed: " << gai_strerror(s) << endl;
throw runtime_error("getnameinfo() failed");
Expand All @@ -79,7 +82,8 @@ string getInterfaceIP(const string& interface)
if (IPs.count(interface) > 0) {
return IPs[interface];
}
LOG(error) << "Could not find provided network interface: \"" << interface << "\"!, exiting.";
LOG(error) << "Could not find provided network interface: \""
<< interface << "\"!, exiting.";
return "";
} catch (runtime_error& re) {
cout << "could not get interface IP: " << re.what();
Expand All @@ -94,9 +98,10 @@ string getDefaultRouteNetworkInterface()
array<char, BUFSIZE> buffer{};
string interfaceName;

#ifdef __APPLE__ // MacOS
unique_ptr<FILE, decltype(pclose) *> file(popen("route -n get default | grep interface | cut -d \":\" -f 2", "r"), pclose);
#else // Linux
#ifdef __APPLE__ // MacOS
unique_ptr<FILE, decltype(pclose)*> file(
popen("route -n get default | grep interface | cut -d \":\" -f 2", "r"), pclose);
#else // Linux
ifstream is("/proc/net/route");
string line;

Expand All @@ -114,14 +119,17 @@ string getDefaultRouteNetworkInterface()

if (line.substr(pos + 1, 8) == "00000000") {
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;
}
}

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

if (!file) {
Expand All @@ -138,8 +146,10 @@ string getDefaultRouteNetworkInterface()
boost::algorithm::trim(interfaceName);

if (interfaceName.empty()) {
LOG(debug) << "Could not detect default route network interface name from /proc/net/route nor 'ip route'";
throw DefaultRouteDetectionError("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 "
"nor 'ip route'";
throw DefaultRouteDetectionError("Could not detect default route network interface name "
"from /proc/net/route nor 'ip route'");
} else {
LOG(debug) << "Detected network interface name for the default route: " << interfaceName;
}
Expand All @@ -149,25 +159,22 @@ string getDefaultRouteNetworkInterface()

string getIpFromHostname(const string& hostname)
{
boost::asio::io_service ios;
return getIpFromHostname(hostname, ios);
}
boost::asio::io_context ioc;

using namespace boost::asio::ip;

string getIpFromHostname(const string& hostname, boost::asio::io_service& ios)
{
try {
namespace bai = boost::asio::ip;
bai::tcp::resolver resolver(ios);
bai::tcp::resolver::query query(hostname, "");
bai::tcp::resolver::iterator end;
tcp::resolver resolver(ioc);
tcp::resolver::query query(hostname, "");
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) {
return ep.address().is_v4();
});
auto it = find_if(static_cast<basic_resolver_iterator<tcp>>(resolver.resolve(query)),
end,
[](const tcp::endpoint& ep) { return ep.address().is_v4(); });

if (it != end) {
stringstream ss;
ss << static_cast<bai::tcp::endpoint>(*it).address();
ss << static_cast<tcp::endpoint>(*it).address();
return ss.str();
}

Expand All @@ -180,4 +187,4 @@ string getIpFromHostname(const string& hostname, boost::asio::io_service& ios)
}
}

} // namespace fair::mq::tools
} // namespace fair::mq::tools
16 changes: 1 addition & 15 deletions fairmq/tools/Network.h
Original file line number Diff line number Diff line change
@@ -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 *
* GNU Lesser General Public Licence (LGPL) version 3, *
Expand All @@ -13,18 +13,6 @@
#include <string>
#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
{

Expand All @@ -41,8 +29,6 @@ std::string getDefaultRouteNetworkInterface();

std::string getIpFromHostname(const std::string& hostname);

std::string getIpFromHostname(const std::string& hostname, boost::asio::io_service& ios);

} // namespace fair::mq::tools

#endif /* FAIR_MQ_TOOLS_NETWORK_H */

0 comments on commit 9585c20

Please sign in to comment.