* 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>
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);
}
}