// $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
-template <class Stream>
+// senf::log::Target::route
+
+#ifndef DOXYGEN
+
+template <class A1>
prefix_ void senf::log::Target::route(action_t action, int index)
{
- route(&Stream::instance(), 0, NONE::value, action, index);
+ route<A1,mpl::nil,mpl::nil>(action, index);
}
-template <class Stream, class Arg>
+template <class A1, class A2>
prefix_ void senf::log::Target::route(action_t action, int index)
{
- route<Arg>(&Stream::instance(), static_cast<Arg*>(0), action, index);
+ route<A1,A2,mpl::nil>(action, index);
}
-template <class Stream, class Area, class Level>
+template <class A1, class A2, class A3>
prefix_ void senf::log::Target::route(action_t action, int index)
{
- route(&Stream::instance(), &Area::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);
}
-template <class Stream>
+template <class A1>
prefix_ void senf::log::Target::unroute(action_t action)
{
- unroute(&Stream::instance(), 0, NONE::value, action);
+ unroute<A1,mpl::nil,mpl::nil>(action);
}
-template <class Stream, class Arg>
+template <class A1, class A2>
prefix_ void senf::log::Target::unroute(action_t action)
{
- unroute<Arg>(&Stream::instance(), static_cast<Arg*>(0), action);
+ unroute<A1,A2,mpl::nil>(action);
}
-template <class Stream, class Area, class Level>
+template <class A1, class A2, class A3>
prefix_ void senf::log::Target::unroute(action_t action)
{
- unroute(&Stream::instance(), &Area::instance(), Level::value, action);
-}
-
-////////////////////////////////////////
-// private members
-
-template <class Area>
-prefix_ void senf::log::Target::route(detail::StreamBase const * stream,
- detail::AreaBase const *, action_t action, int index)
-{
- route(stream, &Area::instance(), NONE::value, action, index);
+ 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 Level>
-prefix_ void senf::log::Target::route(detail::StreamBase const * stream,
- detail::LevelBase const *, action_t action, int index)
-{
- route(stream, 0, Level::value, action, index);
-}
-
-template <class Area>
-prefix_ void senf::log::Target::unroute(detail::StreamBase const * stream,
- detail::AreaBase const *, action_t action)
-{
- unroute(stream, &Area::instance(), NONE::value, action);
-}
-
-template <class Level>
-prefix_ void senf::log::Target::unroute(detail::StreamBase const * stream,
- detail::LevelBase const *, action_t action)
-{
- unroute(stream, 0, 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);
}