mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2025-10-15 09:31:45 +00:00
SDK: Let DDSEnvironment manage $LD_LIBRARY_PATH
* Remove configurable install prefix * Add singleton
This commit is contained in:
committed by
Dennis Klein
parent
5a7bf68c8c
commit
152c8431c6
@@ -20,16 +20,24 @@ namespace mq {
|
||||
namespace sdk {
|
||||
|
||||
// TODO https://github.com/FairRootGroup/DDS/issues/224
|
||||
auto LoadDDSEnv(const boost::filesystem::path& config_home, const boost::filesystem::path& prefix)
|
||||
auto LoadDDSEnv(const boost::filesystem::path& config_home)
|
||||
-> void
|
||||
{
|
||||
setenv("DDS_LOCATION", prefix.c_str(), 1);
|
||||
setenv("DDS_LOCATION", DDSInstallPrefix.c_str(), 1);
|
||||
if (!config_home.empty()) {
|
||||
setenv("HOME", config_home.c_str(), 1);
|
||||
}
|
||||
std::string path(std::getenv("PATH"));
|
||||
path = DDSExecutableDir + std::string(":") + path;
|
||||
setenv("PATH", path.c_str(), 1);
|
||||
|
||||
#ifndef __APPLE__
|
||||
std::string ldVar("LD_LIBRARY_PATH");
|
||||
std::string ld(std::getenv(ldVar.c_str()));
|
||||
ld = DDSLibraryDir + std::string(":") + ld;
|
||||
setenv(ldVar.c_str(), ld.c_str(), 1);
|
||||
#endif
|
||||
|
||||
std::istringstream cmd;
|
||||
cmd.str("DDS_CFG=`dds-user-defaults --ignore-default-sid -p`\n"
|
||||
"if [ -z \"$DDS_CFG\" ]; then\n"
|
||||
@@ -41,31 +49,32 @@ auto LoadDDSEnv(const boost::filesystem::path& config_home, const boost::filesys
|
||||
|
||||
struct DDSEnvironment::Impl
|
||||
{
|
||||
Impl(Path config_home, Path prefix)
|
||||
: fConfigHome(std::move(config_home))
|
||||
, fInstallPrefix(std::move(prefix))
|
||||
explicit Impl(Path config_home)
|
||||
: fCount()
|
||||
, fConfigHome(std::move(config_home))
|
||||
{
|
||||
LoadDDSEnv(fConfigHome, fInstallPrefix);
|
||||
LoadDDSEnv(fConfigHome);
|
||||
if (fConfigHome.empty()) {
|
||||
fConfigHome = std::getenv("HOME");
|
||||
}
|
||||
}
|
||||
|
||||
struct Tag {};
|
||||
friend auto operator<<(std::ostream& os, Tag) -> std::ostream& { return os << "DDSEnvironment"; }
|
||||
tools::InstanceLimiter<Tag, 1> fCount;
|
||||
|
||||
Path fConfigHome;
|
||||
Path fInstallPrefix;
|
||||
};
|
||||
|
||||
DDSEnvironment::DDSEnvironment(Path config_home, Path prefix)
|
||||
: fImpl(std::make_shared<Impl>(std::move(config_home), std::move(prefix)))
|
||||
DDSEnvironment::DDSEnvironment(Path config_home)
|
||||
: fImpl(std::make_shared<Impl>(std::move(config_home)))
|
||||
{}
|
||||
|
||||
auto DDSEnvironment::GetConfigHome() const -> Path { return fImpl->fConfigHome; }
|
||||
|
||||
auto DDSEnvironment::GetInstallPrefix() const -> Path { return fImpl->fInstallPrefix; }
|
||||
|
||||
auto operator<<(std::ostream& os, DDSEnvironment env) -> std::ostream&
|
||||
{
|
||||
return os << "$DDS_LOCATION: " << env.GetInstallPrefix() << ", "
|
||||
return os << "$DDS_LOCATION: " << DDSInstallPrefix << ", "
|
||||
<< "$DDS_CONFIG_HOME: " << env.GetConfigHome() / DDSEnvironment::Path(".DDS");
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user