File: stream.cpp

package info (click to toggle)
libwibble 0.1.19
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 832 kB
  • ctags: 1,940
  • sloc: cpp: 9,798; makefile: 163; perl: 84; sh: 11
file content (55 lines) | stat: -rw-r--r-- 844 bytes parent folder | download | duplicates (2)
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
#include <wibble/log/stream.h>
#include <ostream>

namespace wibble {
namespace log {

Streambuf::Streambuf() : level(defaultLevel), sender(0) {}

Streambuf::Streambuf(Sender* s) : level(defaultLevel), sender(s) {}

Streambuf::~Streambuf()
{
	if (!line.empty())
		send();
}

void Streambuf::setSender(Sender* s) { sender = s; }

void Streambuf::send()
{
	// Send the message
	sender->send(level, line);
	// Reset the level
	level = defaultLevel;
	line.clear();
}

void Streambuf::setLevel(const Level& level)
{
	this->level = level;
}

int Streambuf::overflow(int c)
{
	if (c == '\n')
		send();
	else
		line += c;
	return c;	// or EOF
}

std::ostream& operator<<(std::ostream& s, Level lev)
{
	if (Streambuf* ls = dynamic_cast<Streambuf*>(s.rdbuf()))
	{
		ls->setLevel(lev);
		return s;
	} else
		return s << lev;
}

}
}

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