-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlogging.cpp
67 lines (52 loc) · 1.55 KB
/
logging.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
//
// Created by justanhduc on 20. 11. 18..
//
#include "logging.h"
#include <boost/process.hpp>
#include <chrono>
#include <cstdarg>
#include <ctime>
#include <iostream>
namespace fs = boost::filesystem;
inline int vscprintf(const char *format, va_list pargs) {
/* from https://stackoverflow.com/a/4785411/4591601 */
int retval;
va_list argcopy;
va_copy(argcopy, pargs);
retval = vsnprintf(nullptr, 0, format, argcopy);
va_end(argcopy);
return retval;
}
BaseLogger::BaseLogger() {
std::string homedir = getenv("HOME");
fs::path root(homedir);
fs::path name(filename);
fs::path p = root / name;
ofs.open(p.string(), std::ofstream::out | std::ofstream::app);
if (!ofs) {
std::cerr << "Cannot open " << p.string() << " to write log" << std::endl;
exit(-1);
}
}
void BaseLogger::logTime() {
auto now = std::chrono::system_clock::now();
auto timeNow = std::chrono::system_clock::to_time_t(now);
ofs << std::ctime(&timeNow) << " ";
}
void BaseLogger::log(const char *fmt, ...) {
/* from https://stackoverflow.com/a/3280304/4591601 */
va_list varptr;
va_start(varptr, fmt);
auto n = vscprintf(fmt, varptr);
std::vector<char> buf(n);
::vsprintf(&buf[0], fmt, varptr);
va_end(varptr);
std::copy(buf.begin(), buf.end(), std::ostream_iterator<char>(ofs));
}
void BaseLogger::log(const strings &strs, const std::string &delimiter) {
for (auto &i: strs) {
ofs << i;
ofs << delimiter;
}
}
void BaseLogger::log(const std::string &str) { ofs << str; }