summaryrefslogtreecommitdiffstats
path: root/src/uscxml/interpreter/Logging.h
diff options
context:
space:
mode:
authorStefan Radomski <github@mintwerk.de>2016-12-09 12:25:11 (GMT)
committerStefan Radomski <github@mintwerk.de>2016-12-09 12:25:11 (GMT)
commit9b8e09c3fde755ec26e5c21b9640f53ed9329d05 (patch)
treec7001e5bfc551a24e3cee0b3fb014791e0685b44 /src/uscxml/interpreter/Logging.h
parent9fae96bbf295fcd867d60bf45d9c3b825ae692c2 (diff)
downloaduscxml-9b8e09c3fde755ec26e5c21b9640f53ed9329d05.zip
uscxml-9b8e09c3fde755ec26e5c21b9640f53ed9329d05.tar.gz
uscxml-9b8e09c3fde755ec26e5c21b9640f53ed9329d05.tar.bz2
Removed easylogging due to JNI segfaults
Diffstat (limited to 'src/uscxml/interpreter/Logging.h')
-rw-r--r--src/uscxml/interpreter/Logging.h96
1 files changed, 96 insertions, 0 deletions
diff --git a/src/uscxml/interpreter/Logging.h b/src/uscxml/interpreter/Logging.h
new file mode 100644
index 0000000..7746998
--- /dev/null
+++ b/src/uscxml/interpreter/Logging.h
@@ -0,0 +1,96 @@
+/**
+ * @file
+ * @author 2016 Stefan Radomski (stefan.radomski@cs.tu-darmstadt.de)
+ * @copyright Simplified BSD
+ *
+ * @cond
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the FreeBSD license as published by the FreeBSD
+ * project.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+ *
+ * You should have received a copy of the FreeBSD license along with this
+ * program. If not, see <http://www.opensource.org/licenses/bsd-license>.
+ * @endcond
+ */
+
+#ifndef LOGGING_H_3B1A3A0F
+#define LOGGING_H_3B1A3A0F
+
+#include "uscxml/config.h"
+#include "uscxml/Common.h"
+
+#include "uscxml/messages/Data.h"
+#include "uscxml/messages/Event.h"
+
+#include <memory>
+
+#define LOG(lvl) uscxml::Logger::getDefault().log(lvl)
+#define LOG2(lvl, thing) uscxml::Logger::getDefault().log(lvl, thing);
+
+#define SCXML USCXML_SCXML
+#define TRACE USCXML_TRACE
+#define DEBUG USCXML_DEBUG
+#define INFO USCXML_INFO
+#define WARNING USCXML_WARN
+#define ERROR USCXML_ERROR
+#define FATAL USCXML_FATAL
+
+namespace uscxml {
+
+enum LogSeverity {
+ USCXML_SCXML,
+ USCXML_TRACE,
+ USCXML_DEBUG,
+ USCXML_INFO,
+ USCXML_WARN,
+ USCXML_ERROR,
+ USCXML_FATAL
+};
+
+class LoggerImpl;
+
+void log(LogSeverity severity, const Event& event);
+void log(LogSeverity severity, const Data& data);
+
+class StreamLogger {
+public:
+ std::ostream& operator<<(const std::string& message);
+ ~StreamLogger();
+
+protected:
+ StreamLogger(LogSeverity severity, std::shared_ptr<LoggerImpl> logger) : _severity(severity), _logger(logger) {}
+ StreamLogger(const StreamLogger& other) : _severity(other._severity), _logger(other._logger) {}
+
+ LogSeverity _severity;
+ std::shared_ptr<LoggerImpl> _logger;
+ std::stringstream ss;
+
+ friend class Logger;
+};
+
+class USCXML_API Logger {
+public:
+ PIMPL_OPERATORS(Logger);
+
+ virtual void log(LogSeverity severity, const Event& event);
+ virtual void log(LogSeverity severity, const Data& data);
+ virtual void log(LogSeverity severity, const std::string& message);
+
+ virtual StreamLogger log(LogSeverity severity);
+ static std::string severityToString(LogSeverity severity);
+
+ static Logger getDefault();
+
+ std::shared_ptr<LoggerImpl> getImpl() const;
+protected:
+ std::shared_ptr<LoggerImpl> _impl;
+
+};
+
+}
+
+#endif /* end of include guard: LOGGING_H_3B1A3A0F */