libt2n: (gerd) bugfixes, better logging, unit tests for wrapper, ignore handler still...
[libt2n] / src / client_wrapper.cpp
index af60da9..735ac29 100644 (file)
@@ -24,4 +24,27 @@ namespace libt2n
 
 const char* T2nSingletonWrapperMessages::NotInitializedMessage = "T2nSingletonWrapper used before setting initializing connection";
 
+/// get pointer to logging stream, returns NULL if no logging needed
+std::ostream* ConnectionWrapper::get_logstream(log_level_values level)
+{
+    if (logstream && log_level >= level)
+        return logstream;
+    else
+        return NULL;
+}
+
+/// activate logging to the given stream. everything above the given level is logged.
+void ConnectionWrapper::set_logging(std::ostream *_logstream, log_level_values _log_level)
+{
+    log_level=_log_level;
+    logstream=_logstream;
+}
+
+/// always call this when you got a new connection to transfer logging settings
+void ConnectionWrapper::set_logging_on_connection(client_connection& c)
+{
+    if (logstream != NULL && log_level > none)
+        c.set_logging(logstream,log_level);
+}
+
 }