summaryrefslogtreecommitdiff
path: root/src/logger/logger.cpp
diff options
context:
space:
mode:
authorlouiz’ <louiz@louiz.org>2018-02-05 22:53:36 +0100
committerlouiz’ <louiz@louiz.org>2018-02-05 22:53:36 +0100
commit56651cb5c29cc50ddf3c62c37167fa0b9389bfde (patch)
treeca652963cafeb02b0c6c7504b1cfbc27abdafe0b /src/logger/logger.cpp
parentad1e0f8d52189e18df2d5a39228e255798a9de70 (diff)
parente0d1a0b44add408504e428d6ce4a8a2121ea7a00 (diff)
downloadbiboumi-56651cb5c29cc50ddf3c62c37167fa0b9389bfde.tar.gz
biboumi-56651cb5c29cc50ddf3c62c37167fa0b9389bfde.tar.bz2
biboumi-56651cb5c29cc50ddf3c62c37167fa0b9389bfde.tar.xz
biboumi-56651cb5c29cc50ddf3c62c37167fa0b9389bfde.zip
Merge branch 'master' into debian
Diffstat (limited to 'src/logger/logger.cpp')
-rw-r--r--src/logger/logger.cpp23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/logger/logger.cpp b/src/logger/logger.cpp
index 92a3d9b..482cb18 100644
--- a/src/logger/logger.cpp
+++ b/src/logger/logger.cpp
@@ -1,12 +1,35 @@
#include <logger/logger.hpp>
#include <config/config.hpp>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <unistd.h>
+
Logger::Logger(const int log_level):
log_level(log_level),
stream(std::cout.rdbuf()),
null_buffer{},
null_stream{&null_buffer}
{
+#ifdef SYSTEMD_FOUND
+ if (!this->use_stdout())
+ return;
+
+ // See https://www.freedesktop.org/software/systemd/man/systemd.exec.html#%24JOURNAL_STREAM
+ const char* journal_stream = ::getenv("JOURNAL_STREAM");
+ if (journal_stream == nullptr)
+ return;
+
+ struct stat s{};
+ const int res = ::fstat(STDOUT_FILENO, &s);
+ if (res == -1)
+ return;
+
+ const auto stdout_stream = std::to_string(s.st_dev) + ":" + std::to_string(s.st_ino);
+
+ if (stdout_stream == journal_stream)
+ this->use_systemd = true;
+#endif
}
Logger::Logger(const int log_level, const std::string& log_file):