File: filters.h

package info (click to toggle)
libwibble 1.1-1
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd, stretch
  • size: 1,040 kB
  • ctags: 2,721
  • sloc: cpp: 14,542; makefile: 196; perl: 87; sh: 26
file content (63 lines) | stat: -rw-r--r-- 1,297 bytes parent folder | download | duplicates (3)
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
#ifndef WIBBLE_LOG_FILTERS_H
#define WIBBLE_LOG_FILTERS_H

#include <wibble/log/stream.h>
#include <vector>

namespace wibble {
namespace log {

/**
 * Prepend timestamps to log lines
 *
 * Timestamps are generated with a strftime format string on POSIX systems, or
 * with simple asctime() on windows.
 *
 * Strftime expands using a buffer 256 characters wide. Please keep that in
 * mind when creating the format string: longer outputs will be truncated.
 */
struct Timestamper : public Sender
{
	Sender* next;
	std::string fmt;

	Timestamper(Sender* next = 0, const std::string& fmt = "%b %e %T ");
	virtual ~Timestamper();

	virtual void send(Level level, const std::string& msg);
};

/**
 * Log only messages whose level is >= minLevel
 */
struct LevelFilter : public log::Sender
{
	Sender* next;
	log::Level minLevel;

	LevelFilter(Sender* next = 0, log::Level minLevel = log::INFO);
	virtual ~LevelFilter();

	virtual void send(log::Level level, const std::string& msg);
};

/**
 * Send the same message to multiple streams
 */
struct Tee : public log::Sender
{
	std::vector<Sender*> next;

	Tee();
	// Shortcut to initialise with two streams
	Tee(Sender* first, Sender* second);
	~Tee();

	virtual void send(log::Level level, const std::string& msg);
};

}
}

// vim:set ts=4 sw=4:
#endif