summaryrefslogtreecommitdiff
path: root/!NotAdopted/XSoundNotify/DebugLogger.hpp
diff options
context:
space:
mode:
authorKirill Volinsky <mataes2007@gmail.com>2012-07-23 13:52:57 +0000
committerKirill Volinsky <mataes2007@gmail.com>2012-07-23 13:52:57 +0000
commit89c5b2369413025e1fe7dfe5c5d0bf3bedd8558d (patch)
tree18f09394ce3b811e3df7d15de747e842000bd4ad /!NotAdopted/XSoundNotify/DebugLogger.hpp
parenta9580df150d799246eaecbf3c1fb5cecf9f8ab49 (diff)
git-svn-id: http://svn.miranda-ng.org/main/trunk@1123 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to '!NotAdopted/XSoundNotify/DebugLogger.hpp')
-rw-r--r--!NotAdopted/XSoundNotify/DebugLogger.hpp91
1 files changed, 91 insertions, 0 deletions
diff --git a/!NotAdopted/XSoundNotify/DebugLogger.hpp b/!NotAdopted/XSoundNotify/DebugLogger.hpp
new file mode 100644
index 0000000000..3b2c5a5fc1
--- /dev/null
+++ b/!NotAdopted/XSoundNotify/DebugLogger.hpp
@@ -0,0 +1,91 @@
+#ifndef _GRS_DEBUG_LOGGER_H
+#define _GRS_DEBUG_LOGGER_H
+
+#include <fstream>
+#include <sstream>
+#include <ctime>
+#include <memory>
+
+/**
+ * Простой логгер, который можно использовать в любом месте для вывода отладочной информации
+ * При выводе обычного сообщения надо использовать макрос GRS_DEBUG_LOG
+ * Для вывода сложного сообщения с использованием операторов ввода/вывода макрос GRS_DEBUG_FORMAT_LOG
+ * Лог сохраняется в рабочем каталоге под именем : grs_debug.log
+ */
+
+namespace grs
+{
+
+class DebugLogger
+{
+public:
+ class Except : public std::exception
+ {
+ public:
+ virtual const char * what() const throw() { return "pizda rulu"; }
+ };
+
+ DebugLogger()
+ {
+ try
+ {
+ _strm.open("D:\\grs_debug.log", std::ios::app);
+ }
+ catch (...)
+ {
+ throw Except();
+ }
+ if (!_strm.is_open())
+ throw Except();
+
+ log("Logger started");
+ }
+
+ void log(const std::string & str, const char * fileStr = 0, int line = 0)
+ {
+ if (!_strm.is_open())
+ return ;
+
+ time_t t(time(0));
+ struct tm * timeinfo;
+ timeinfo = localtime (&t);
+ char timeStr[9];
+ strftime (timeStr, 9, "%H:%M:%S", timeinfo);
+ _strm << "[" << timeStr << "] ";
+ if (fileStr)
+ _strm << fileStr << ":" << line<<" ";
+ _strm <<"# "<< str << std::endl;
+ }
+
+ static DebugLogger * instance()
+ {
+ //static DebugLogger * logger = 0;
+ static std::auto_ptr<DebugLogger> loggerPtr;
+ if (loggerPtr.get() == 0)
+ loggerPtr.reset(new DebugLogger());
+ return loggerPtr.get();
+ }
+
+private:
+ std::ofstream _strm;
+};
+
+}
+
+#define GRS_DEBUG_FORMAT_LOG(data) {\
+ grs::DebugLogger * l = grs::DebugLogger::instance();\
+ if (l != 0) \
+ {\
+ std::stringstream strm;\
+ strm << data;\
+ l->log(strm.str(), __FILE__, __LINE__);\
+ }\
+ }
+
+#define GRS_DEBUG_LOG(data) {\
+ grs::DebugLogger * l = grs::DebugLogger::instance();\
+ if (l != 0)\
+ l->log(data, __FILE__, __LINE__);\
+ }
+
+#endif