File: Logging.cpp

package info (click to toggle)
structure-synth 1.5.0-2
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 2,268 kB
  • ctags: 1,966
  • sloc: cpp: 10,209; python: 164; makefile: 71; sh: 15
file content (61 lines) | stat: -rw-r--r-- 1,587 bytes parent folder | download | duplicates (9)
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
#include "Logging.h"


#ifdef WIN32
#include "windows.h"
#endif

/// TODO's
/// - Nested log entris
/// - Time
/// - Setting a log view level


namespace SyntopiaCore {
	namespace Logging {	
		QVector<Logger*> Logger::loggers;
		QStack<QTime> Logger::timeStack;
		QStack<QString> Logger::timeStringStack;

		void LOG(QString message, LogLevel priority) {
			
			// On Windows this allows us to see debug in the Output::Debug window while running.
			#ifdef WIN32
				OutputDebugString((LPCWSTR) (message+"\r\n").utf16());
			#endif

			for (int i = 0; i < Logger::loggers.size(); i++) {
				Logger::loggers[i]->log(message, priority);
			}
		}

		/// Useful aliases
		void Debug(QString text) { LOG(text, DebugLevel); }
		void INFO(QString text) { LOG(text, InfoLevel); }
		void WARNING(QString text) { LOG(text, WarningLevel); }
		void CRITICAL(QString text) { LOG(text, CriticalLevel); }
		
		void TIME(QString text) {
			LOG(text, TimingLevel);

			Logger::timeStack.push(QTime::currentTime());
			Logger::timeStringStack.push(text);
		} ;
		
		void TIME(int repetitions) {
			QTime t = Logger::timeStack.pop();
			QString s = Logger::timeStringStack.pop();
			int secs = t.msecsTo(QTime::currentTime());
			if (repetitions == 0) {
				LOG(QString("Time: %1s for ").arg(secs/1000.0f) + s, TimingLevel);
			} else {
				LOG(QString("Time: %1s for %2. %3 repetitions, %4s per repetition.").arg(secs/1000.0f).arg(s)
					.arg(repetitions).arg((secs/repetitions)/1000.0f), TimingLevel);			
			}
		}; // End time...
		

	
	}
}