X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Utils%2FLogger%2FFileTarget.hh;h=5a80a7a0c84081cb382d43fbb9b4c57299d23c0e;hb=61dc3812717cdc89fa2402006d4009236b72dc8f;hp=9bc933194a6a6916739d9dd8f64635ce80fab180;hpb=f73fa16ed5abdce272ac77f8b8b9ef2b9922c266;p=senf.git diff --git a/Utils/Logger/FileTarget.hh b/Utils/Logger/FileTarget.hh index 9bc9331..5a80a7a 100644 --- a/Utils/Logger/FileTarget.hh +++ b/Utils/Logger/FileTarget.hh @@ -1,8 +1,8 @@ // $Id$ // -// Copyright (C) 2007 -// Fraunhofer Institute for Open Communication Systems (FOKUS) -// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Copyright (C) 2007 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund // // This program is free software; you can redistribute it and/or modify @@ -23,11 +23,12 @@ /** \file \brief FileTarget public header */ -#ifndef HH_FileTarget_ -#define HH_FileTarget_ 1 +#ifndef HH_SENF_Utils_Logger_FileTarget_ +#define HH_SENF_Utils_Logger_FileTarget_ 1 // Custom includes #include +#include #include #include "IOStreamTarget.hh" @@ -35,14 +36,24 @@ ///////////////////////////////hh.p//////////////////////////////////////// namespace senf { + + namespace console { class DirectoryNode; } + namespace log { - /** \brief Log target writing to a log file. + /** \brief Log target writing to a %log file. - The FileTarget will save all log messages in the given file. Messages will be appended at + The FileTarget will save all %log messages in the given file. Messages will be appended at the end of the file. - After log files have been rotated, the reopen() member should be called to create a new log + \code + senf::log::FileTarget target ("file.name"); + + // Route all messages to this file. + target.route(); + \endcode + + After %log files have been rotated, the reopen() member should be called to create a new %log file. \ingroup targets @@ -58,16 +69,26 @@ namespace log { ///\name Structors and default members ///@{ - explicit FileTarget(std::string file); ///< Construct FileTarget writing to \a file + explicit FileTarget(std::string const & filename, std::string const & nodename = ""); + ///< Construct FileTarget writing to \a file ///@} /////////////////////////////////////////////////////////////////////////// - void reopen(); ///< Reopen log after log-file rotation - void reopen(std::string file); ///< Reopen log under a new name + void reopen(); ///< Reopen %log after log-file rotation + void reopen(std::string const & file); ///< Reopen %log under a new name + + std::string const & filename() const; ///< Return current log file name private: std::string file_; + + struct RegisterConsole { + RegisterConsole(); + static boost::shared_ptr create( + std::string const & filename, std::string const & nodename); + static RegisterConsole instance; + }; }; }}