/usr/include/bobcat/log is in libbobcat-dev 4.08.02-2build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | #ifndef INCLUDED_BOBCAT_LOG_
#define INCLUDED_BOBCAT_LOG_
#include <fstream>
#include <memory>
#include <bobcat/logbuffer>
namespace FBB
{
enum LogManipulator
{
FATAL,
nl,
};
class Log: private LogBuffer, public std::ostream
{
private:
static std::unique_ptr<Log> s_stream;
std::ofstream d_stream;
size_t d_level;
size_t d_activeLevel;
public:
static Log &instance();
static Log &initialize(std::string const &filename,
std::ios::openmode = std::ios::out | std::ios::app,
char const *delim = " ");
Log();
Log(std::ostream &out, char const *delim = " ");
Log(std::string const &filename,
std::ios::openmode = std::ios::out | std::ios::app,
char const *delim = " ");
void open(std::string const &filename,
std::ios::openmode = std::ios::out | std::ios::app,
char const *delim = " ");
size_t level() const; // .f
std::ostream &level(size_t useLevel);
void setLevel(size_t newLevel);
void setTimestamp(TimeStamps timeStamp, char const *delim = " ");
void off(); // .f
private:
void init();
};
inline size_t Log::level() const
{
return d_level;
}
inline void Log::off()
{
setActive(false);
}
std::ostream &operator<<(std::ostream &str, LogManipulator);
} // FBB
#endif
|