// $Id$
//
-// Copyright (C) 2007
-// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
-// Kompetenzzentrum fuer NETwork research (NET)
+// Copyright (C) 2007
+// Fraunhofer Institute for Open Communication Systems (FOKUS)
+// Competence Center NETwork research (NET), St. Augustin, GERMANY
// Stefan Bund <g0dil@berlios.de>
//
// This program is free software; you can redistribute it and/or modify
/** \file
\brief Target inline template implementation */
-//#include "Target.ih"
+#include "Target.ih"
// Custom includes
#include "Levels.hh"
// senf::log::Target::route
-template <class Stream>
-prefix_ void senf::log::Target::route(action_t action, int index)
-{
- route(&Stream::instance(), 0, NONE::value, action, index);
-}
+#ifndef DOXYGEN
-template <class Stream, class Level>
-prefix_ void senf::log::Target::
-route(action_t action, int index,
- typename boost::enable_if< boost::is_convertible<Level*, detail::LevelBase *> >::type *)
-{
- route(&Stream::instance(), 0, Level::value, action, index);
-}
-
-template <class Stream, class Area>
-prefix_ void senf::log::Target::
-route(action_t action, int index,
- typename boost::enable_if< boost::is_convertible<Area*, detail::AreaBase *> >::type *)
-{
- route(&Stream::instance(), &Area::instance(), NONE::value, action, index);
-}
-
-template <class Stream, class AreaClass>
-prefix_ void senf::log::Target::
-route(action_t action, int index,
- typename boost::enable_if< boost::is_convertible<typename AreaClass::SENFLogArea *, detail::AreaBase *> >::type *)
+template <class A1>
+prefix_ void senf::log::Target::route(action_t action, int index)
{
- route(&Stream::instance(), &AreaClass::SENFLogArea::instance(), NONE::value, action, index);
+ route<A1,mpl::nil,mpl::nil>(action, index);
}
-template <class Stream, class Area, class Level>
-prefix_ void senf::log::Target::
-route(action_t action, int index,
- typename boost::enable_if< boost::is_convertible<Area *, detail::AreaBase *> >::type *)
+template <class A1, class A2>
+prefix_ void senf::log::Target::route(action_t action, int index)
{
- route(&Stream::instance(), &Area::instance(), Level::value, action, index);
+ route<A1,A2,mpl::nil>(action, index);
}
-template <class Stream, class AreaClass, class Level>
-prefix_ void senf::log::Target::
-route(action_t action, int index,
- typename boost::enable_if< boost::is_convertible<typename AreaClass::SENFLogArea *, detail::AreaBase *> >::type *)
+template <class A1, class A2, class A3>
+prefix_ void senf::log::Target::route(action_t action, int index)
{
- route(&Stream::instance(), &AreaClass::SENFLogArea::instance(), Level::value, action, index);
+ typedef detail::RouteParameters<A1,A2,A3> Params;
+ route( detail::InstanceP<typename Params::Stream, detail::StreamBase>::value(),
+ detail::InstanceP<typename Params::Area, detail::AreaBase>::value(),
+ Params::Level::value,
+ action, index);
}
-// senf::log::target::ununroute
-
-template <class Stream>
+template <class A1>
prefix_ void senf::log::Target::unroute(action_t action)
{
- unroute(&Stream::instance(), 0, NONE::value, action);
-}
-
-template <class Stream, class Level>
-prefix_ void senf::log::Target::
-unroute(action_t action,
- typename boost::enable_if< boost::is_convertible<Level*, detail::LevelBase *> >::type *)
-{
- unroute(&Stream::instance(), 0, Level::value, action);
-}
-
-template <class Stream, class Area>
-prefix_ void senf::log::Target::
-unroute(action_t action,
- typename boost::enable_if< boost::is_convertible<Area*, detail::AreaBase *> >::type *)
-{
- unroute(&Stream::instance(), &Area::instance(), NONE::value, action);
+ unroute<A1,mpl::nil,mpl::nil>(action);
}
-template <class Stream, class AreaClass>
-prefix_ void senf::log::Target::
-unroute(action_t action,
- typename boost::enable_if< boost::is_convertible<typename AreaClass::SENFLogArea *, detail::AreaBase *> >::type *)
+template <class A1, class A2>
+prefix_ void senf::log::Target::unroute(action_t action)
{
- unroute(&Stream::instance(), &AreaClass::SENFLogArea::instance(), NONE::value, action);
+ unroute<A1,A2,mpl::nil>(action);
}
-template <class Stream, class Area, class Level>
-prefix_ void senf::log::Target::
-unroute(action_t action,
- typename boost::enable_if< boost::is_convertible<Area *, detail::AreaBase *> >::type *)
+template <class A1, class A2, class A3>
+prefix_ void senf::log::Target::unroute(action_t action)
{
- unroute(&Stream::instance(), &Area::instance(), Level::value, action);
+ typedef detail::RouteParameters<A1,A2,A3> Params;
+ unroute( detail::InstanceP<typename Params::Stream, detail::StreamBase>::value(),
+ detail::InstanceP<typename Params::Area, detail::AreaBase>::value(),
+ Params::Level::value,
+ action);
}
-template <class Stream, class AreaClass, class Level>
-prefix_ void senf::log::Target::
-unroute(action_t action,
- typename boost::enable_if< boost::is_convertible<typename AreaClass::SENFLogArea *, detail::AreaBase *> >::type *)
-{
- unroute(&Stream::instance(), &AreaClass::SENFLogArea::instance(), Level::value, action);
-}
+#endif
///////////////////////////////////////////////////////////////////////////
-// namespace senf::log members
+// namespace senf::log::detail members
template <class Stream, class Area, class Level>
-prefix_ void senf::log::write(std::string msg)
+prefix_ void senf::log::detail::write(std::string const & msg)
{
TargetRegistry::instance().write(Stream::instance(), Area::instance(), Level::value, msg);
}