libt2n: (gerd) more documentation-polishing
[libt2n] / src / client_wrapper.cpp
index 5115d20..735ac29 100644 (file)
  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
  ***************************************************************************/
 
-#include <iostream>
-#include <string>
-
-#include <functional>
-
-#include <boost/any.hpp>
-#include <boost/bind.hpp>
-#include <boost/function.hpp>
-
-#include "../codegen/codegen-stubhead.hxx"
-
-
 #include <client_wrapper.hxx>
 
-#include <wrapper_handler_socket.hxx>
-
 namespace libt2n
 {
 
-class testme : public command_client
-{
-    public:
-
-    testme(client_connection &x, long long a, long long b)
-        : command_client(x,100000,10000)
-        { }
-
-    void helloworld(const std::string& text)
-    {
-        std::cout << "Hello world, " << text << std::endl;
-    }
-};
-
 const char* T2nSingletonWrapperMessages::NotInitializedMessage = "T2nSingletonWrapper used before setting initializing connection";
 
-typedef T2nSingletonWrapper<testme> wraptype;
-
-template<>
-std::auto_ptr<wraptype> wraptype::SingletonObject = std::auto_ptr<wraptype>();
-
-template<>
-std::auto_ptr<ConnectionWrapper> wraptype::WrappedConnection = std::auto_ptr<ConnectionWrapper>();
-
-void test(void)
+/// 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;
+}
 
-    t2n_exec(&testme::helloworld)("gurke");
-
+/// 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);
 }
 
 }