mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2026-02-04 03:19:21 +00:00
Boost 1.88 replaced Boost.Process with v2, breaking the v1 API. Boost 1.89 restores v1 compatibility via <boost/process/v1.hpp>. - Fail configuration if Boost 1.88 is detected - Define FAIRMQ_BOOST_PROCESS_V1_HEADER for Boost >= 1.89 - Use conditional includes to select v1.hpp or process.hpp - Add namespace aliases (bp, bp_this) for portable API access
55 lines
2.0 KiB
C++
55 lines
2.0 KiB
C++
/********************************************************************************
|
|
* Copyright (C) 2021 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
|
* *
|
|
* This software is distributed under the terms of the *
|
|
* GNU Lesser General Public Licence (LGPL) version 3, *
|
|
* copied verbatim in the file "LICENSE" *
|
|
********************************************************************************/
|
|
|
|
#include "Manager.h"
|
|
|
|
// Needed to compile-firewall the <boost/process/async.hpp> header because it
|
|
// interferes with the <asio/buffer.hpp> header. So, let's factor
|
|
// the whole dependency to Boost.Process out of the header.
|
|
#ifdef FAIRMQ_BOOST_PROCESS_V1_HEADER
|
|
#include <boost/process/v1.hpp>
|
|
namespace bp = boost::process::v1;
|
|
#else
|
|
#include <boost/process.hpp>
|
|
namespace bp = boost::process;
|
|
#endif
|
|
#include <fairlogger/Logger.h>
|
|
|
|
namespace fair::mq::shmem {
|
|
|
|
bool Manager::SpawnShmMonitor(const std::string& id)
|
|
{
|
|
auto const env(boost::this_process::environment());
|
|
std::string const fairmq_path_key("FAIRMQ_PATH");
|
|
std::string const shmmonitor_exe_name("fairmq-shmmonitor");
|
|
std::string const shmmonitor_verbose_key("FAIRMQ_SHMMONITOR_VERBOSE");
|
|
auto path(boost::this_process::path());
|
|
|
|
if (env.count(fairmq_path_key)) {
|
|
path.emplace(path.begin(), env.at(fairmq_path_key).to_string());
|
|
}
|
|
|
|
auto exe(bp::search_path(shmmonitor_exe_name, path));
|
|
if (exe.empty()) {
|
|
LOG(warn) << "could not find " << shmmonitor_exe_name << " in \"$" << fairmq_path_key
|
|
<< ":$PATH\"";
|
|
return false;
|
|
}
|
|
|
|
// TODO Move this to fairmq-shmmonitor itself ?
|
|
bool verbose(env.count(shmmonitor_verbose_key)
|
|
&& env.at(shmmonitor_verbose_key).to_string() == "true");
|
|
|
|
bp::spawn(
|
|
exe, "-x", "-m", "--shmid", id, "-d", "-t", "2000", (verbose ? "--verbose" : ""), env);
|
|
|
|
return true;
|
|
}
|
|
|
|
} // namespace fair::mq::shmem
|