// $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
+// senf::log::Target::route
+
+#ifndef DOXYGEN
+
template <class Stream>
-prefix_ void senf::log::Target::route(action_t action)
+prefix_ void senf::log::Target::route(action_t action, int index)
+{
+ route(&Stream::instance(), 0, NONE::value, action, index);
+}
+
+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(), 0, NONE::value, action);
+ route(&Stream::instance(), &Area::instance(), NONE::value, action, index);
}
-template <class Stream, class Arg>
-prefix_ void senf::log::Target::route(action_t action)
+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 *)
{
- route<Arg>(&Stream::instance(), static_cast<Arg*>(0), action);
+ route(&Stream::instance(), &AreaClass::SENFLogArea::instance(), NONE::value, action, index);
}
template <class Stream, class Area, class Level>
-prefix_ void senf::log::Target::route(action_t action)
+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(), Level::value, action);
+ route(&Stream::instance(), &Area::instance(), Level::value, action, index);
}
-////////////////////////////////////////
-// private members
+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 *)
+{
+ route(&Stream::instance(), &AreaClass::SENFLogArea::instance(), Level::value, action, index);
+}
+
+// senf::log::target::ununroute
+
+template <class Stream>
+prefix_ void senf::log::Target::unroute(action_t action)
+{
+ unroute(&Stream::instance(), 0, NONE::value, action);
+}
-template <class Area>
-prefix_ void senf::log::Target::route(detail::StreamBase const * stream,
- detail::AreaBase const *, action_t 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 *)
{
- route(stream, &Area::instance(), NONE::value, action);
+ unroute(&Stream::instance(), 0, Level::value, action);
}
-template <class Level>
-prefix_ void senf::log::Target::route(detail::StreamBase const * stream,
- detail::LevelBase const *, action_t 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 *)
{
- route(stream, 0, Level::value, action);
+ unroute(&Stream::instance(), &Area::instance(), NONE::value, 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 *)
+{
+ unroute(&Stream::instance(), &AreaClass::SENFLogArea::instance(), NONE::value, 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 *)
+{
+ unroute(&Stream::instance(), &Area::instance(), 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 msg)
{
TargetRegistry::instance().write(Stream::instance(), Area::instance(), Level::value, msg);
}
+template <class Source>
+prefix_ void senf::log::timeSource()
+{
+ timeSource(std::auto_ptr<Source>(new Source()));
+}
+
///////////////////////////////cti.e///////////////////////////////////////
#undef prefix_